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This user guide provides machine room operating information for the 
Prime PRIMOS operating systems. The operating procedures are systems 
oriented rather than hardware oriented. Information is organized as 
follows: 



Section 1 



Section 2 



Section 3 



Section 4 



Section 5 



Section 6 



Section 7 



Discusses operation of the PRIMOS II operating 

system, which is fundamentally a single-user disk-based 

operating system. 

Discusses operation of PRIMOS III, which is a virtual 
memory, multi-user operating system for the Prime 300. 
Section 2 also gives many tips and details on PRIMOS III 
system generation and configuration. 

Discusses operation of PRIMOS IV, the operating 
system for the Prime 400. PRIMOS IV is a virtual 
memory operating system which takes advantage of the 
Prime 400 architecture and segmentation to 
provide the user with both a vast amount of 
virtual memory space and faster execution of user 
programs. 

Is a detailed description to guide the user 
in running FIXRAT, a file and disk maintenance command. 
This section is important to the user who wishes to 
maintain the integrity of his computer system 
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i ftp 



Describes MAKE, a command that allows the user 

to build his own unique disks from the Prime-supplied 

master disk volumes. 

Describes PRIMOS III IV internal commands. 
These commands are normally used by the operator 
at the supervisor terminal in the computer room. 

Describes COPY, a command that allows the user to 

copy one disk surface to another. COPY is important to 

PRIMOS II system initialization. 



Section 8 An overview of PRIMOS systems 

operation presented in the form of a sample of 
operating procedures at an existing 
computer site. 

Appendix A Discusses the different bootstrap facilities 

that are available to the user for bootstrapping the 
operating system into the computer system memory. 

Appendix B Describes disk record header formats for 
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both 448-word and 1040-word records. 



REFERENCE DOCUMENTS 

This user guide is written with the assumption that the computer room 
operator is familiar with the mechanical operating procvedures for 
equipment such as the CPU control panel, the various disks and their 
associated control panmels, and peripheral devices. The following 
table references documents that detail operating procedures for various 
equipment items that are commonly present within Prime computer 
configurations. 



DOCUMENT NUMBER 
MAN1671 

MAN1672 
MAN1940 
MAN1942 
MAN1946 
MAN1948 
MAN1949 
MAN2798 



TITLE 

SYSTEMS REFERENCE USER GUIDE 
(for Prime 100, 200, 300) 

OPERATORS GUIDE 

MAGNETIC TAPE USER GUIDE 

LINE PRINTER USER GUIDE 

TERMINAL USER GUIDE 

FIXED AND MOVING HEAD DISKS USER GUIDE 

DISKETTE USER GUIDE 

PRIME 400 SYSTEMS REFERENCE USER GUIDE 
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noTMriC tt AmrDaTiTrfla 



This section describes how to load and start PRIMOS II, summarizes the 
essential operator tasks during an operating session, and describes 
PRIMOS II equipment configuration details. 



OVERVIEW OF PRIMOS II OPERATION 

Sectored Mode and Relative Mode 

Two versions of PRIMOS II are supplied on the master disk, 
sectored-mode and relative-mode PRIMOS II. Sectored-mode PRIMOS II is 
11000 (octal) locations in size and is loaded in 32S addressing-mode. 
It cannot be loaded or even called from above 32K. Relative-mode 
PRIMOS II is currently 14000 (octal) locations in size and is loaded in 
64R addressing-mode. Relative mode PRIMOS II can be loaded or called 
from above 32K, and it supports the storage module disk drive as 
file-system device. 

Sectored-mode PRIMOS II and relative-mode PRIMOS II are supplied loaded 
for various memory sizes in both real-memory and virtual-memory 
configurations. The real-memory configurations run stand-alone on any 
Prime processor. The virtual-memory configurations run in user-space 
under the PRIMOS III or PRIMOS IV operating system on a Prime 300 or 
400 processor. 

The locations and names of the PRIMOS II configurations on the master 
disk as supplied as follows: 



January 1977 



SECTION 1 



MAN2603 



UFD File Contents 

DOS *DOS16 16K real-memory S-DOS 

DOS *DOS24 24K real-memory S-DOS 

DOS SDOS32 32K real-memory S-DOS 

DOS *DOS32 32K real-memory R-DOS 

DOS *DOS64 64K real-memory R-DOS 

DOS VDOS16 16K virtual-memory S-DOS 

DOS VDOS24 24K virtual-memory S-DOS 

DOS VDOS32 32K virtual-memory S-DOS 

DOS UDOS32 32K virtual-memory R-DOS 

CMDNC0 DOSEXT saved-file containing hybr 

CMDNC0 DOSXT saved-file containing hybr 



Low Restart High 

027000 030000 037777 

047000 050000 057777 

067000 070000 077777 

064000 070000 077777 

164000 170000 177777 

027000 030000 037777 

047000 050000 057777 

067000 070000 077777 

064000 070000 077777 

id commands for S-DOS 

id commands for P-DOS 



The banner printed when relative-mode PRIMOS II is loaded is: 

PRIMOS II REV 11.0 07/15/76 (AT nnnnnn) 

where nnnnnn is the restart location. The banner printed when 
sectored-mode PRIMOS II is loaded is: 

DOS REV. 10.0 2/19/76 (AT nnnnnn) 

Bootstrap Loading 

When a master disk is loaded from the processor control panel, the 
bootstrap assesses the size of main-memory physically present on the 
machine and loads file *DOSnn from UFD DOS, where nn is 16, 24, 32 or 
64, depending upon main-memory size. The bootstrap no longer limits nn 
to 32 on 64K machines. Sense switches 1-3 are used to limit the memory 
size determination to less than the available physical memory. The 
sense switch settings are: 



00XXXX 


highest DOS that will fit; 


04XXXX 


*D0S16; 


06XXXX 


*DOS24; 


16XXXX 


*DOS32; 


else 


error. 



With the UFD named DOS, the bootstrap loads sectored-mode PRIMOS II in 
16K and 24K machines and relative-mode PRIMOS II in 32K and 64K 
machines. An installation may desire to rename *DOS32 to RDOS32 and 
SDOS32 to *DOS32. Thereafter, the bootstrap loads sectored-mode PRIMOS 
II in a 32K machine at that installation. The selection can be 
reversed by renaming *DOS32 to SODS32 and RDOS32 to *DOS32 again. 

It is possible but undesirable to load and use relative-mode PRIMOS II 
in 16K and 24K configurations, because of the reduced amount of main 
memory left. It is impossible, to load sectored mode PRIMOS II above 
32K. 
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On systems with a storage module disk drive, ary version of PRIMOS II 
can be bootstrap-loaded from the storage module. The sense switch 
settings are XX0114. However, sectored-mode PRIMOS II does not support 
the storage module as a file-system device and can make no further 
reference to it. Relative-mode PRIMOS II supports the storage module 
fully as a file-system device. 

Virtual-Memory PRIMOS in CMDNC0 

With the availability of 64K PRIMOS II, the virtual-memory PRIMOS III 
supplied in UFD CMDNC0 of the master disk has been changed from VDOS32 
(32K sectored-mode PRIMOS III) to UDOS64 (64K relative-mode PRIMOS 
III) . VDOS32 continues to be supplied, but it is now in the UFD named 
DOS. 

Supervisor Calls to Relative-Mode PRIMOS II 

Ihe restriction that all supervisor calls be confined to the first 32K 
of main memory is removed with relative-mode PRIMOS II. Programs 
operating in 64R addressing mode can run and make supervisor calls from 
anywhere in 64K of memory, above or below the operating system. Of 
course, programs operating in 32S or 32R addressing modes are confined 
to the first 32K of memory, and programs operating in 16S addressing 
mode are confined to the first 16K of memory. However , all of these 
programs may run with and make supervisor calls to a relative-mode 
PRIMOS II located anywhere in 64K of memory. Table 1-1 gives a list of 
the disk assignment numberse for all PRIMOS systems. For the storage 
module physical disk, refer to the paragraph on STORAGE MODULE in this 
section. 



DISKS 

The following table (Table 1-1) lists the physical numbers and the 
types of disks that may be used when running PRIMOS II. Subsequent 
paragraphs discuss logical disk number, disk data transfer and disk 
partitioning. 
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Table 1-1. Physical Disk Numbers. 



Physical 

Disk 

Drive Controller 

Number Option Description Sectors/Track 

4000 Removable surface of first MH 8 

(moving head) disk drive (upper 
surface) 

1 4000 Fixed surface of first MH disk 8 

drive (lower surface) 

Removable surface of second MH disk 8 
drive (upper surface) 

Fixed surface of second MH disk 8 

drive (lower surface) 

Removable surface of third MH disk 8 
drive (upper surface) 

Fixed surface of third MH disk drive 8 
(lower surface) 

4000 Removable surface of fourth MH disk 8 
drive (upper surface) 

4000 Fixed surface of fourth MH disk 8 

drive (lower surface) 

First fixed head disk drive 8 

First floppy disk drive 4 

Second floppy disk drive 4 

Third floppy disk drive 4 

Fourth floppy disk drive 4 

Fifth floppy disk drive 4 

Sixth floppy disk drive 4 

Seventh floppy disk drive 4 



2 


4000 


3 


4000 


4 


4000 


5 


4000 



10 


4000 


20 


4300 


21 


4300 


22 


4300 


23 


4300 


24 


4300 


25 


4300 


26 


4300 
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27 


4300 




Aaao 


31 


4002 


32 


4002 


33 


4002 


34 


4002 


36 


4002 
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Eighth floppy disk drive 4 

Removable surf see of first MH 8 

(moving head) disk drive (upper 

surface) 

Fixed surface of first MH disk 8 

drive (lower surface) 

Removable surface of second MH 8 

disk drive (upper surface) 

Fixed surface of second MH disk 8 

drive (lower surface) 

Removable surface of third MH 8 

disk drive (upper surface) 

Removable surface of fourth MH disk 8 
drive (upper surface) 

37 4002 Fixed surface of fourth MH disk drive 8 
(lower surface) 

40 4002 Fixed head disk drive 64 

50 4002 Removable surface of first MH (moving- 32 

head) disk drive (upper surface) 

51 4002 Fixed surface of first MH disk drive 32 

(lower surface) 

52 4002 Removable surface of second MH disk 32 

drive (upper surface) 

53 4002 Fixed surface of second MH disk 32 

drive (lower surface) 

54 4002 Removable surface of third MH disk 32 

drive (upper surface) 

55 4002 Fixed surface of third MH disk drive 32 

(lower surface) 

56 4002 Removable surface of fourth MH disk 32 

drive (upper surface) 

57 4002 Fixed surface of fourth MH disk drive 32 

(lower surface) 
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5050 4003/4002 First 30-million word MH 32 

disk drive (controller address = 21) 

5052 4003/4002 Second 30-million word MH 32 

disk drive (controller address = 21) 

5054 4003/4002 Third 30-million word MH 32 

disk drive (controller address = 21) 

5056 4003/4002 Fourth 30-million word MH 32 

disk drive (controller address = 21) 

5250 4003/4002 First 30-million word MH 32 

disk drive (controller address = 23) 

5252 4003/4002 Second 30-million word MH 32 

disk drive (controller address = 23) 

5254 4003/4002 Third 30-million word MH 32 

disk drive (controller address = 23) 

5256 4003/4002 Fourth 30-million word MH 32 

disk drive (controller address = 23) 



NOTES TO TABLE 1-1: 

The logical-to-physical assignment depends on the order in which the 
physical device numbers are listed as parameters in the STARTUP com- 
mand. The physical device number specified in the Ldisk0 position is 
assigned as logical disk unit 0, the physical device number specified 
in the Ldiskl position is assigned as logical disk unit 1, and so on. 

Example : 

STARTUP 5054 5056 5052 5050 

The physical disks are 5054,5056,5052, and 5050; where: 

physical 5054 is logical 0, physical 5056 is logical 1, physical 
5052 is logical 3, and physical 5050 is logical 4. The number of 
parameters in STARTUP indicate to PRIMOS II the number of logical 
drives assigned to the system. 



CAUTION: 
When changing disks, a SHUTDN is required. Otherwise, PRIMOS 
will use parameters (such as record availability) applicable 
to the previous replaced disk with possible loss of file di- 
rectories. With SHUTDN, PRIMOS II shuts down all disks, and 
PRIMOS III allows specific disks to be shut down. 
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The codes shown in Table I-i ere used in the STARTUP command and the 
ASSIGN command (refer to the Interactive User's Guide (MAN 2602)). The 
codes are also used by the utility commands FIXRAT, MAKE, and COPY 
(refer to Sections 4, 5, and 6). 

The physical device codes are the same for three- or six -mill ion word 
disk drivers connected to the controller. 

The storage module disk is fully supported using a record of 102 words. 
For further information, refer to the paragraphs describing storage 
module support, later in this section. 

Data Transfer Between Disks 

An eight-sector/track disk pack written on a drive connected to the 
4000 controller cannot be read on a drive connected to the 4002 con- 
troller and vice-versa, because the method of computing hardware check- 
sum written on the pack is different on the two controllers. A special 
conversion program to convert packs written on one controller to read 
on the other controller must be written. A 32-sector/track pack cannot 
be read or written on a drive connected to the 4000 controller. An at- 
tempt to read a 32-sector/track pack using physical device numbers for 
an eight-sector/track pack will fail. Similarly, an attempt to read an 
eight-sector /track pack using physical device numbers for a 32 sector/ 
track pack will fail. It is important to keep straight the 
identification of the disk pack. Each pack should be labeled with the 
range of physical device numbers appropriate to the disk pack. 

Unlike the other disks, only even numbered physical disk drive numbers 
are allowed for the 30-million word disk drives. There may be up to 
four drives connected to a type 4001/4002 controller that is configured 
to the system. The default device address for a type 4003/4002 con- 
troller is 21, and the disk drive numbers associated with this drive 
are 5050, 5052, 5054, and 5056. Similarly, a 4G03 or 4002 controller 
may have a device address of 23, and disk drive numbers associated with 
this controller are 5250, 5252, 5254 and 5256. A system configuration 
could have two type 4003/4002 controllers and up to eight 30-million 
word disks connected. 

Partitioning Disks 

A user may partition a 30-million word disk into two or more sub-disks, 
via use of the MAKE command (refer to Section 4) . Each partition of a 
disk (sub-disk) is treated by the system commands, PRIMOS, FIXRAT and 
COPY, as if it were a physically separate disk. Each sub-disk contains 
its own MFD, DSKRAT, BOOT, CMDNC0, etc. Partitions are defined by a 
starting head address (relative to head of the disk) , a number of 
contiguous heads and the physical disk number. The minimum partition 
contains two heads (i.e., three million words). When a partition of a 
30-million word disk is present, the physical disk number varies from 
those shown in Table 1-1. The number of heads is reflected in the 
second two digits. Tables 1-2 and 1-3 are useful in constructing 
partitions (the X 's represent "don't care" octal digits). 
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The physical disk number defining a partition on a disk is generateo by 
merqinq the head offset with the number of heads and witn the oisk de- 
vice number. For the purposes of forming a physical disk number for a 
partitioned disk, the physical disk device numbers are considered to 
be: 50, 52, 54, and 56 for disks on disk drives 1 to 4 on the type 
4003/4002 controller. 

Example : 

The physical disk number for a disk partition having a head offset 
of 00 and the number of heads of 20 would be calculated as 
follows: (assume that the device address of the type 4003/ 400^. 
controller is 21) : first, look up at the appropriate numbers in 
Tables 1-2 and 1-3, then 

head offset + number of heads + physical disk device number 
00XXXX + XX50XX + 56 = 005956 

As another example, consider a disk split into two partitions with 
the disk being the first disk on the type 4003/4002 controller 
with device address 23; the first portion has neao offset - 
heads and number of heads =10. The physical rlisk for the first 
partition is: 



00XXXX 



XX26XX + 50 = 002650 



The second partition has head-offset = 10 heads and num- 
ber-of-heads =10. The physical disk for the second partition is: 



05XXXX 



XX24XX + 50 = 05250 



Physical Device Numbers Usage 

The physical device codes described previously in this section are used 
in the ASSIGN, CONFIG, DISKS, SHUTDN, STARTUP, STATUS, and UNftSSIOl 
commands. These device codes are also used by the utilities FIXRAT, 
FUTIL, MAKE, and COPY. 
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Table 1-2. Head Offset Definitions. 



Offset 



Physical Disk Numbers 



heads 


00XXXX 


2 heads 


01XXXX 


4 heads 


02XXXX 


6 heads 


03XXXX 


8 heads 


04XXXX 


10 heads 


05XXXX 


12 heads 


06XXXX 


14 heads 


07XXXX 


16 heads 


10XXXX 


18 heads 


11XXXX 
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Table 1-3. Number of Heads Definition. 



Number of Heads 



Type 4003/4002 
Controller 

Address = 21 (default) 
Physical Disk Number 



Type 4003/4002 
Controller 
Address=23 (explicit) 
Physical Disk Number 



2 heads 


(default) 


XX00XX 


2 heads 


(explicit) 


XX0400 


4 heads 




XX10XX 


6 heads 




XX14XX 


8 heads 




XX20XX 


10 heads 




XX24XX 


12 heads 




XX30XX 


14 heads 




XX34XX 


16 heads 




XX40XX 


18 heads 




XX44XX 


20 heads 




XX50XX 



XX02XX 
XX06XX 
XXI 2XX 
XX16XX 
XX22XX 
XX26XX 
XX32XX 
XX36XX 
XX42XX 
XX46XX 
XX52XX 



STORAGE MODULE DISK SUPPORT 



Record Size and Format 



Relative-mode PRIMOS II supports the storage module disk drive, both 
80- and 300-million byte sizes. 

The storage module uses a physical record size of 1040 words instead of 
448 words. The storage module is the only disk device to use a 
physical record size other than 448 words. The physical record size is 
of concern to users in subroutine PRWFIL (refer to MAN 2604) in 
absolute position requests and in requests to return to the current 
position. It is also of concern in user calls to subroutine GINFO. 
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The concept of a virtual record size is introduced for programming 
convenience and consistency. A virtual record is constant on any disk 
and is 448 words oer record (ei«ht words of header followed b" 440 data 
words) . Thus, a file can be specified in terms of record number and 
word number. The record number/word number pair used to specify 
absolute position then becomes a convenient way of specifying a 
position in a file, if that absolute position requires more than 16 
bits for complete specification. 

Storage Module Disk Number 

The encoding of the storage module disk numbers is as follows: 

The type is 6. 

The number-of-heads field and the head-offset field rre identical to 
the corresponding fields on the 30-million word disk. For details, 
refer to the discussion on head offset and number-of-heads calculation 
in this section, and Tables 1-2 and 1-3. unlike the 30-million word 
disk specification, the low-order bit of the disk number is combined 
with the number-of-heads field to specify the addition of one head to 
the partition. Only the last partition of a storage module disk may 
contain an odd number of heads, since there is no way to specify an odd 
head offset. The following examples demonstrate these principles. 

Value Meaning 

60 Not allowed; does not default 

to two heads. 

1061 Five-head partition, no offset, 
first unit of first controller. 

1063 Five-head partition, no offset, 
second unit. 

1261 Five-head partition, no offset, 
first unit of second controller. 

1060 Four -head partition, no offset, 
first unit. 

20061 One-head partition, four- 
head offset, first unit. 



A more detailed explanation of the storage module physical device 
number involves its coding as seen below: 
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FFFFHHHHA0110UUH 



Bits 1-4 (FFFF) comprise the head offset divided by two. Bits 5-8 and 
16 (HHHH) are the number of heads in the partition (minimum 2, maximum 
5; bit 9 (A) is the alternate controller bit (controller '26 if reset, 
'27 if set) . Bits 10-13 comprise the device type, which is 6 for 
storage module, and bits 14-15 (UU) the unit number. 

Buffer Size 

PRIMOS II selects its buffer size at the time of the STARTUP command. 
If no storage module devices are started up, PRIMOS runs with 448 (700 
octal) word buffers. If any storage module devices are started up, 
buffers are 1042 (2022 octal) words long. The STATUS command types out 
the selected buffer size. When holding a storage module record, the 
larger buffer is organized as 16 (20 octal) words for header, 1024 
(2000 octal) words of data, and two words for an error detecting and 
correcting code checksum. When holding a smaller record, the larger 
buffer is organized as eight (10 octal) words unused, eight (10 octal) 
words of header, 440 (670 octal) words of data, and the remainder 
unused. The format of a storage module record header is: 



+0,+l 


current record address; 


+2, +3 


father record address; 


+4 


data word count; 


+5 


file type; 


+6, +7 


next record address; 


+8, +9 


previous record address; 


+10... +15 


spares, must be zero. 


Header Size 





To identify the header size as 16 words, the high-order bit of the type 
field is set in the headaers of records and 2 only of any storage 
module partition (the headers of the BOOT and the first record of the 
DSKRAT) . Partition sizes on a storage module are limited to five heads 
in size. This restricts record addresses to single-word integers and 
permits storage module headers to be transformed, when in memory 
buffers, into the same eight-word format used by all other devices. 

File System Calls with Storage Module 

All file system calls operate as described in the File System User 
Guide MAN 2604. The user program need not be aware that it is 
accessing a storage module device. Position information transmitted in 
PRWFIL calls is treated as if all records had a data size of 440 (670 
octal) words, regardless of whether or not that is the actual record 
size. 



REV. A 1-12 



MAN2603 PRIMOS II OPERATION 



PRWFIL calls, that request the read-convenient state, terminate 
transfers of 1024 (instead of 448) words on the storage module. If a 
smaller butter size is speciriea te.g., ^o-wulus; , tne smaj.±ei. wui-i-s^ 
is not overrun and all existing user programs continue to run correctly 
with stroage module devices. 

UFD's on Storage Module 

The size of a UFD is still limited to one physical record. However, 
the larger record dize permits UFD's to contain (1024-8) /6 = 169 
entries on storage module devices. UFD's are limited to 72 entries on 
other devices. 

DAM Files on Storage Module 

Due to the larger size of index and data records, direct-access files 
on storage module devices have a longer reach before access becomes 
sequential. The first 1048576 (4000000 octal) words of a storage 
module file are within direct-access reach. Only the first 193600 
(572100 octal) words of files on other devices are within direct-access 
reach. 

Segment directory operation is unchanged. Any user application program 
employing segmented files will continue to run correctly on stroage 
module devices at this revision. The limitation of storage module 
partition sizes to five heads keeps file-system record addresses 
confined to single-word integers for Revision 11. 

Storage Module Error Detection 

The storage module controller writes a two-word correcting code 
checksum on each record. It is a five-code generated by the following 
polynomial : 

G(X) = X** (1+X**2+1)*(X**21+1) 

An error detection and correction scheme (ECC) is implemented for the 
storage module. The code, together with the correction logic in the 
storage module controller is capable of detecting any of the following: 
(1) up to two error bursts of combined length up to 22 bits; (2) a 
single error burst of up to length 32 bits; and (3) any odd number of 
errors. In addition, the ECC algorithm is capable of correcting any 
single error burst of up to 11 bits in length. Error correction is 
attempted only after ten attempts to read a record have failed. The 
storage module reads by the operating systems. 

The message printed when storage module error correction is attempted 
and fails is: 
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UNCORRECTABLE 

The message printed when error correction succeeds is: 

Wordno Error Error 

Wordno is the offset relative to the beginning 

of the record at the beginr-ina of the 
correction. 

Error Error is the 32-bit correction pattern 
(two-16-bit words) (of which 
at most, 11 consecutive bits 
will be non-zero) . 

The normal disk error message is of the form: 

DISK PD ER <physical deviceXrecord addressXCRAXdisk status word> 

CRA is valid only on read requests. CRA is the identifier on the 
record read, which should match the requested record <record address>. 
The disk status word for the storage module disk is as follows: 



Status Word 


Meaning 


177777 


Bad record identifier 


177776 


Device not ready 


100000 


Always set 


040000 


DMX overrun 


010000 


Check error 


004000 


Checksum error 


002000 


Header check failure 


000010 


Disk drive seeking 


000004 


Illegal seek 


000002 


Select error 


000001 


Not available or not i 



The storage module controller supports ECC. A few existing customers 
may require a field update to the controller to run current software. 

Control Panel BOOT from Storage Module 

The control panel boot program (refer to Appendix A) has been modified 
to support the storage module. Customers must obtain Rev. G PROM for 
the purpose of BOOTING from the storage module. The sense switch 
setting to boot from the storage module is 114 octal. The boot types 
the message: 

PHYSICAL DEVICE = 
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The user then types the appropriate device number for the storage 
module . 

CAUTION 

The BOOT does not boot from the storage module if the boot is read 
from a disk other than a storage module. 

Procedure for Storage Module Users to Convert to a 1040-Word Format 

1. Bring up REV. 10, PRIMOS III or IV. 

2. Move all files from the storage module disks to either 
magnetic tape or other disks. Use MAGSAV to move files to 
magnetic tape. Use FUTIL (MAN 2604) to move files to non- storage 
module disks. 

3. Bring up PRIMOS II (formerly DOS). 

4. MAKE the storage module disks with saved information (refer to 
Section 5) . Use the VIRGIN DISK and VERIFY DISK option of MAKE to 
reformat the entire disk for large records. Be sure to run the 
current version of MAKE. MAKE all partitions on the disk, 
including the paging partition. 

5. Use MAGRST (MAN 2602) or FUTIL to move files back to the 
storage module packs. 

6. If a pack or partition of a pack is to be used for BOOTING, 
move *DOS32 and *DOS64 to the named UFD DOS from the master disk 
volume 1. 

7. Flush all commands from CMDNC0 and replace with commands from 
the current master disk. 

8. Bring up PRIMOS III or IV according to the directions in 
Sections 2 and 3 of this user guide. 

User File Directories (UFD's) are constrained to be one physical 
record. Because the storage module has larger records, it is possible 
that more files than may be described by the entries in a single UFD 
may possibly be stored in a UFD (up to 169 files) . 

As the storage capacity of the storage module disk is so large, the 
disk must be partitioned to keep the number of records per partition 
below 65,536 (64K) . The largest allowable partition is eight heads 
containing 59,256 records. The 80MB five-head storage module can be 
one partition; the 19-head storage module must be split into three 
partitions. 



- 15 January 1977 



SECTION 1 MAN2603 



If a storage module is available, PRIMOS II can be loaded from it. The 
sense switch settings are 000114 (highest PRIMOS II that will fit into 
available memory) or 100114 (32K PRIMOS II) . Sectored-mode PRIMOS II 
does not support the storage module as a device; therefore, 16K or 24K 
PRIMOS II may not be bootloaded when it is necessary to access a 
storage module. 



STARTUP OF PRIMOS III 

Once PRIMOS II is started and running, PRIMOS III can be started (for 
details, refer to Section 2). To invoke PRIMOS HI, give the command: 
PRIMOS3. Note that the response of PRIMOS III to a valid command is: 
OK, ("OK" followed by comma, not a colon) , which indicates which of the 
operating systems has control. 

STARTUP OF PRIMOS IV 

PRIMOS IV is also started from PRIMOS II. For details, refer to 
Section 3. To invoke PRIMOS IV, give the command: 

PRIMOS 



INITIAL PRIMOS II OPERATING SESSION 

Attaching to UFD 

After a STARTUP, the user must attach to a User File Directory to 
execute PRIMOS II commands and create or manipulate files. To 
determine which spare UFD's are available, ATTACH to the MFD and do a 
LISTF: 

OK: A MFD XXXXXX 
OK: LISTF 

UFD=MFD 

DSKRAT MFD BOOT CMDNC0 LIB SRCLIB DIAG PMA 

FORTRN LDR BASIC FLIB1 FLIB2 FLIB3 FLIB4 FLIB5 

FLIB6 LIB7 LIB8 IOCS AIDS ED BINED TM 

PRIMII RTOS PRIMOS IIVM RTOSVM INDEX 

Note that the MFD has a password, XXXXXX, which acts as the default at 
the time the disk is MADE'd, to discourage casual or inadvertent use of 
this important directory. 
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CAUTION 

Do not attach to MFD for a program development or normal file 
handling tasks. Be very careful in entering commands while 
attached to this UFD, FIXRAT can be used to fix the disk if the 
UFD's DOS, BOOT, or CMDNC0 are intact; but if any of the files in 
this MFD are damaged, the master disk is compromised. 

DISK BUILDING (COPYING MASTER DISK PACK) 

Disk building consists of three phases: format the disk; move run 
files of PRIMOS II (*DOS16, *DOS24, *DOS32, *DOS64, as appropriate) 
onto the UFD named DOS; move any desired external commands onto the 
UFD CMDNC0 and/or move libraries onto the UFD LIB. 

Format of PRIMPS II Disk 

If a PRIMOS II master disk (or any other PRIMOS II disk) is available, 
it can be COPY'd onto the virgin disk. Unneeded files on a new pack 
can be deleted and new files can be created. 

If no PRIMOS II disk is available and an empty disk is desired, the 
MAKE program can be run (the COPY and MAKE programs are described in 
Sections 5, and 6. When a disk is formatted using MAKE, any needed 
files are then copied from the master disk onto the new disk; other 
files and programs can be created later. If you plan to bootload from 
this new disk, then the UFD named DOS must contain the files *D0S16, 
*DOS24, *DOS32, and *DOS64. MAKE ensures than an executable and 
correct BOOT is written onto record of the disk. 

PRIMOS II supports the storage module disk and the Terminet system 
terminal. Those users with 64K or more contiguous memory invoke a 
PRIMOS II loaded at the top of 64K, following the BOOT procedure (refer 
to Appendix A) . If this version of PRIMOS II is inconvenient for users 
with programs accessing these locations, the user may request that a 
32K PRIMOS II be loaded by setting sense switches 1-4 before BOOTing. 

The newer features of PRIMOS II provide 3000 additional octal 
locations; however, 16K and 24K PRIMOS are unchanged. The commands 
LOAD and PSD, as supplied on the master disk, do not run with 32K 
PRIMOS II. In the event that users have programs too large to run with 
the larger versions of PRIMOS II, 32K PRIMOS II is supplied as file 
SDOS32 in the UFD named DOS. To cause this version to be BOOTed, 
ATTACH to the UFD named PRIMOS and perform the following CNAME 
comments : 

CNAME *DOS32 RDOS32 
CNAME SDOS32 *DOS32 

Then, BOOT DOS, as described in this section and Appendix A. 



- 17 January 1977 



SECTION 1 MAN2603 



The commands FTN, ED, and PMA cannot be used with *DPS16 or *DOS24. 
*D0S16 or *DOS24 users must use the commands SFTN, SED, and SPMA. SFTN 
does not support 32-bit integers. It is suggested that DOS16 and DOS24 
users delete FTN, ED, and PMA from their command directory (CMDNC0) and 
rename (CNAME) : SFTN to FTN, SED to ED, and SPMA to PMA for ease of 
operation. 



Building a PRIMPS II Disk from Paper Tape 

Disk packs can be ordered with full CMDNC0 etc.; however, if no PRIMPS 
II formatted disks are available, one must be created from 
Prime-supplied paper tapes. All tapes provided are MDL self-loading 
tapes and are loaded into memory using the control panel boot. The 
first step is to load MAKE and run it (refer to Section 5) . The 

fnl Inwina ryrnr-arii-ira io rofflii roH • 

1. Load BDOSV2 (PRIMPS II bootstrap tape) . This loads the loader 
*PRIMPS 1116 as well as other necessary modules. 

Start at '6765. 

After the header is typed and PRIMPS II prompts PK:, type the fol- 
lowing commands: 

STARTUP (Pdev) where Pdev is a physical device number. 

ATTACH PRIMPS II 

SAVE *PRIMOS 1116 7000 17777 31000 20000 2000 

2. Boot the new *PRIMOS 1116 from the disk using either: 

Control panel boot (Sense Switch 2 set) 

Paper tape PRIMPS IIBOPT (SLT-start at '1000) . Set Sense 
Switch 2 after the tape has been loaded. 

3. Any other command can be added by loading it into memory 
(control panel boot) , starting at '30000 (Starting Address, SA, of 
PRIMPS II, ATTACHing to CMDNC0 and SAVEing the command) . Refer to 
the Interactive Users' Guide (MAN 2602) for a description of these 
commands. 

4. Use EDB to read any binary files (e.g., FTNLIB) from paper 
tape. 

5. Use ED to read any source files (e.g., DRATIT) from paper 
tape. 
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Once the disk is READY, the user can resume PRIMOS II operation. A new 
STARTUP is required. 

Example : 

OK: STARTUP 5051 

This establishes the fixed surface as logical unit 0; all PRIMOS II 
disk activity supporting the assembler, compiler, editor (etc.) uses 
logical unit 0. 

Creating Additional PRIMOS II Disks 

Every PRIMOS II disk must contain a BOOT, a DSKRAT file, an MFD, the 
command UFD (e.g., CMDNC0) . The user must add the command programs 
FIXRAT, COPY, and the required UFD's. The easiest way to convert a 
blank disk pack to a PRIMOS II disk is to run the MAKE program (refer 
to the MAKE command description in Section 5) . Another method is to 
copy the active PRIMOS II disk from its present location (for example, 
from the fixed surface to the removable surface of a moving head disk 
drive which is accomplished as follows: 

OK: COPY (Copy operation begins) 

Any nutiber of PRIMOS II compatible disk packs can be made in this way. 
Of course, much of the available file space on an original PRIMOS II 
master disk is occupied. To make room, the user can delete duplicate 
UFD's or files on a new pack (original) as required. Only the PRIMOS 
II disk assigned as logical unit needs to have the full set of PRIMOS 
II command files, UFD's, library, etc. On other disks to be used 
mainly for user's data or program files, the surplus UFD's and the 
files within them, can be deleted. To determine that the files provide 
the most space, run a FIXRAT to observe the number of disk records 
occupied by each UFD. To delete UFD's, attach to the MFD and enter 
DELETE commands. 

Examplle : 

OK: A MFD XXXXXX 

FUTIL 
>TREDEL LIB 

>TREDEL PMA 



>TREDEL FORTRAN 
> QUIT 

OK: 



New UFD's can be created with the CREATE command. Alternatively, if 
the user needs many UFD's, he could use CNAME to change the UFD names, 
then attach to the UFD's and delete the files within them, using FUTIL 
(refer to the File System User's Guide, MAN 2604. 
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Entering New UFD's 

Another method for coining new UFD names is to attach to the MFD and 
use the CREATE command. 

Example : 

OK: A MFD XXXXXX 

OK: CREATE BDAWES 

The above creates a new UFD named BDAWES in the MFD. The user must 
attach to a UFD other than the MFD as soon as possible, to reduce the 
likelihood of spoiling any of the MFD files. 

v_i. cct l. xi iy a ouu~ucu 

The command sequence: 

A BDAWES 
CREATE BOB 

creates a UFD named BOB that is subordinate to the UFD named BDAWES. 
To attach to this sub-UFD, the user issues the command: 

A BOB 1/2 

For further details about attachment, refer to the Interactive Users' 
Guide (MAN 2602) . 

PROGRAM DEVELOPMENT USING PRIMOS II 

The user is free to use PRIMOS II and its supporting software to 
create, assemble or compile, load, save, and execute user programs. 
The internal and external PRIMOS II commands are described in the 
Interactive Users' Guide (MAN 2602) . The appropriate manuals provide 
detailed information on the Editors, FORTRAN, BASIC. The Macro 
Assembler, Loader, and other programs are described in the Programs 
Software Development User Guide (MAN 1879) . 

Refer to the Interactive Users' Guide (MAN 2602) for an example of the 
terminal printout resulting from the development of a simple FORTRAN 
program. The user may study the example and use its procedures as a 
guide during initial program development efforts. 

Recovering from Errors 

If an equipment failure or program error causes the CPU to leave PRIMOS 
II control, it is usually possible to return to PRIMOS II by starting 
the CPU at location '30000, '50000, or '70000, depending on the 
hardware configuration and available memory. See the Operators Guide 
for instructions to restart at these locations. 
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Installing New External Commands 

Thp> lispr ran insl-all his own nis-t-ntn nfil il-v <~>r rldwii-e cririi-rr,~\ nrnnramc 

to be invoked by external command to PRIMOS II. One way this is done 
is by restoring a program from the user 's UFD, and then saving it under 
the command UFD CMDNC0. Assume, for example, that the user wants to 
install a cassette recording and playback monitor program to be invoked 
by the name CASS: 

Example : 

When PRIMOS II prints the message, OK:, the first command to be entered 
must be a STARTUP command that assigns the logical disk 0. PRIMOS II 
expects to find all its command and utility files on disk 0. For 
detailed information on the STARTUP command, refer to the Interactive 
User's Guide. The usual initial STARTUP is: 

OK: STARTUP 50 51 

This assigns the removable surface of the moving head disk (the master 
disk pack) as logical unit 0, and the fixed surface as logical unit 1. 

OK: A USER1 

OK: REST CSETVl 

OK: PM 
SA,EA,P,A,B,X,K= 
000100 011100 001000 000000 000000 000000 000000 

OK: A CMDNC0 

OK: SAVE CASS 100 11100 1000 

OK: A USER1 
OK: CASS 
GO 



(CASS program begins running) 



In this example, the user restores file CSETVl from his own UFD 
(USER1) , and does a PM to determine the RVEC parameters (discussed in 
the Interactive User 's Guide) . He then attaches to CMDNC0 and saves 
the program under the name CASS, with the same parameters as the 
original. Thereafter, when he uses the name CASS as an external com- 
mand, PRIMOS II resumes the saved CASS program. 

One way to install a new external command is: 

OK: A NEWUFD 
OK: FUTIL 
> FROM USER1 
>T0 CMDNC0 
>COPY CSETVl CASS 



- 21 January 1977 



SECTION 1 MAN2603 



NOTE: 

This copies file CSETV1 to the UFD 
named CMDNC0 as a file named CASS. 

>QUIT 
OK: 

Commands for starting up disks under PRIMOS III: 

Another way to install a new external command is: 

ADDISK [PHYDEV] [PHYDEV] ... 

This command searches for available logical number (up to octal 21) and 
does the STARTUP. 

BACKUP 

General 

Each installation can develop its own procedures to save copies of 
files and disks for backup purposes. The techniques are simple. 
PRIMOS II disks can be copied to removable disk packs by careful use of 
the COPY command described in Section 6, or individual files can be 
saved on paper tape through the Text or Binary Editors. 

To copy the fixed disk surface to a removable backup pack (not the 
master disk) : first, do a FIXRAT of the fixed surface and do not 
proceed until an error-free FIXRAT pass is obtained. Then, do the 
appropriate STARTUP, attach to some UFD, and use the COPY command. 

CAUTION 

Before entering the COPY command, make sure the FROM 
surface being copied is in WRITE PROTECT mode. 

Use of MAGSAV 

If magnetic tape devices are present, files are copied to them by the 
MAGSAV command. This is the most convenient and simplest method of 
implementing system backup. The tapes produced by MAGSAV can also be 
read back into the system configuration by use of the MAGRST command 
(refer to MAN 2602) . 

SHUTDOWN 

Before terminating an operating session with PRIKCS II by loading 
another operating system or turning off power, enter the following com- 
mands: 
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OK: FIXRAT (This step is optional) 

OK: SHUTDN 

The SHUTDN command writes to disk PRIMOS II data that is buffered in 
memory. 

Changing Disk Packs 

To change removable disk packs in the moving-heaa disk drive, shut down 
PRIMOS II as above. Then power down the <Hsk drive and replace the 
pack. If PRIMOS III or TV is the system in control, SHUT DOWN the 
physical disk with the SHUTDN command, then cycle down the disk. 
Restart the disk drive. When the unit is READY, give the STARTUP com- 
mand appropriate to the operation with the new pack; and continue 
typing commands. 

Using FIXRAT 

The external command FIXRAT loads and starts the PRIMOS maintenance 
program that checks the file integrity on any disk pack. FIXRAT fully 
supports nested UFD's and nested segment directories. Section 4 gives 
further information on the FIXRAT command. 

FIXRAT must be run whenever there is reason to expect that the file 
structure is damaged - for example, if a program being debugged runs 
wild and writes over part of PRIMOS II. Until the user gains 
experience with the system, FIXRAT should be run at the close of every 
operating session. 

The suggested procedure is to maintain a PRIMOS II disk pack and to run 
FIXRAT every morning; if no error occurs, copy the disk pack onto a 
daily backup disk pack. If any files are truncated or deleted, these 
may be copied from the daily backup disk pack, providied they were 
stored previously on the daily backup disk pack. 

Turning Power Off 

After a shutdown, the CPU can be used to run other software or power 
can be turned off. The following power-down order is recommended: 

1. Disk drives 

2. ASR, high-speed tape unit, and other peripheral devices 

3. Prime CPU 



- 23 January 1977 



SECTION 1 



MAN2603 



RESTARTING PRIMOS II 



CAUTION 



If you are unfamiliar with the system, do not attempt to 
restart PRIMOS II. Check with someone who knows the system's 
hardware status, the contents of all disk surfaces, and the 
correct STARTUP procedure for the particular installation. 

A typical procedure to restart PRIMOS II after a shutdown is: 

1. Turn on power and boot PRIMOS II into control. 

2. Give the appropriate STARTUP command. For example, in a system 
with a fixed/removable moving-head disk drive, the usual 
startup is STARTUP 50 51. This establishes the fixed surface 
as the PRIMOS II command disk. 

3. ATTACH to an authorized UFD and resume operation. 
Terminal Patch Locations 

PRIMOS can be patched to drive terminals of various brands and speeds, 
as explained in the Terminal User Guide (MAN 1946) . The patch 
locations are shown in the table below. 

Some terminals require a few charaacter-times of delay at the end of 
each line to avoid garbling the next line. Relative-mode PRIMOS II is 
provided with a patch location to determine the delay it transmits. 
The location must be set to the number of character-times of delay 
desired. Rubout characters (octal 377) are transmitted during the 
delay. Sectored-mode PRIMOS II does not have such a patch location. 



Function 

Number delays at line end 
Option-A control word 
SOC control word one 
SOC control word two 



Factory 


Location 




Location 




Setting 


in S<-DOS 




in R<-DOS 







(none) 




restart + 


310 


000110 


restart + 


246 


restart + 


311 


000027 


restart + 


247 


restart + 


312 


074000 


restart + 


250 


restart + 


313 



Building Relative-Mode PRIMOS II 

As PRIMOS II is supplied already built 
unlikely that a customer will need 
procedure is as follows: 



on 
to 



the master 
build ine. 



disk, it is 
However, the 



All source modules and command files for building relative-mode PRIMOS 
II are in UFD PR2SRC of Volume 2 of the master disk. UFD PR2BIN, also 
on Volume 2, is supplied initially empty, but receives the binary and 
run files as they are constructed. 
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The command files (in order) which build relative-mode PRAIMOS II ere: 

File Function 

(X-LDOT Builds a utility for relocating run-file address 

parameters as required by the bootstrap loader (refer 
to Appendix A) ; 

(X-FTN Performs all FORTRAN compilations; 
CX-PMA Performs all PMA assemblies; 

(X-LDX Loads DOSXT, the hybrid-command run-file; 

CX-LD32 Loads RDOS32 and UDOS32 (CAUTION: do not run 

this command file under 32K DOS - it will overwrite 
the operating system) ; 

CX-LD64 Loads RDOS64 and UDOS64 (CAUTION: do not run 

this command file under 64K DOS - it will overwrite the 
operating system) ; 

C<-COPY Copies the created run-files into the UFDs named 
DOS and CMDNC0. 



Pitfalls to Avoid 

Relative-mode PRIMOS II is larger than sectored-mode PRIMOS II. Some 
programs that ran under 32K sectored-mode PRIMOS II will not run under 
32K relative-mode PRIMOS II. In particular, the commands LOAD and PSD 
supplied in UFD CMDNC0 of the master disk are loaded too high to 
operate under 32K relative-mode PRIMOS II, use LOAD20 and PSD20 
instead. Of course, there is no problem using LOAD and PSD under 64K 
PRIMOS II. 

Furthermore, upcoming revisions of the master disk may add considerable 
functionality to relative-mode PRIMOS II, and, consequently, its size 
is expected to grow larger in the future. Users should avoid 
configuring their applicatdions programs to be dependent upon a 
specific size operating system. But in consideration of existing 
programs already demanding as much memory as possible, a compact 
sectored-mode PRIMOS II will continue to be supplied. 

Some users are accustomed to keeping the PRIMOS II restart location in 
the sense switches so that it can be easily restarted. With 64K PRIMOS 
II, this is not recommended, as it requires Sense Switch 1 to be SET. 
Setting Sense Switch 1 may produce undesired results with the FTN, PMA, 
and MDL commands. 
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Floppy Disk Troubleshooting 

If floppy disks do not run correctly under relaKve-mode PRIMOS II, try 
the following procedure: 

1. Bootload PRIMOS II from the floppy disk or any other device. 
Do not issue STARTUP command. 

2. From the processor control panel, enter the patch shown 

below and restart PRIMOS II at X70000 <X=0 for 32K, X=l for 64K) . 
The PRIMOS II in memory now runs floppy disks properly. 

3. STARTUP devices. 

4. Make permanent patches to files *DOS32 and *DOS64 in UFD DOS. 

4.1 RESTORE *DOS32 (or *DOS64) and PM. 

4.2 Use TAP to enter patch (not PSD). 

4.3 SAVE with original PM parameters. 

5. If your installation uses UDOS32 or UDOS64, the same 
patch may be necessary in them. The patch is best done 
under PRIMOS III or PRIMOS IV) . 



SAVE/RI 


]ST Loc Loc 


Contents Were 


Contents Should Be 


007763 


X67763 


junk 


005005 


4 


4 


junk 


022020 


5 


5 


junk 


01002b 


6 


6 


junk 


API (7)001 


7 


7 


junk 


005002 


007770 


X67770 


junk 


103771 


1 


1 


junk 


162000 


2 


2 


junk 


000020 


013340 


X73340 


junk 


X67762 


013546 


X73546 


005362 


121571 
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PRIMOS III SYSTEM OVERVIEW 

PRIMOS III shares the computer resources among a community of up to 31 
simultaneous users in a virtual memory environment. 

The resources shared are the central processor, high-speed memory, the 
file system, and the peripheral devices which are also assignable to 
only one user. Each user is provided with a terminal to interact with 
PRIMOS III and a 64K word virtual memory space. Any user can access 
files on disks using the same commands and system subroutines that are 
available when running under PRIMOS II. Other peripheral devices, such 
as the paper tape reader, may be used in the same manner as under 
PRIMOS II, provided they are first assigned to the user by means of the 
ASSIGN command. Under PRIMOS III, users are protected from interfering 
with each other, and user privacy is assured. No user can peek into 
another user's memory to find out what the other user is doing, and no 
user can alter another user 's memory. Under bc*-h PRIMOS II and PRIMOS 
III, disk files can be protected by passwords on file directories. 



PRIMOS III VERSIONS 

There are three general classes of PRIMOS III: four-user versions, 
15-user versions, and 31-user versions. The folowing paragraphs des- 
cribe in detail the content of the existing versions of PRIMOS III. 
Command files that may be invoked to generate the various versions of 
PRIMOS II are described after the description of their contents. 

Standard PRIMOS III 

PRIMOS III now consists of three run files in the UFD named PRIMOS, 
PRMOSL, and PRMOSU. PRIMOS is a utility program that preloads the 
paging device with the file PRMOSU (the upper part of PRIMOS III) and 
RESUMES PFMOSL. 

To invoke PRIMOS III, the user must give the command: 

PRIMOS (standard default) 

This version of PRIMOS supports 15 users on the Prime 300 with either 
an 8- or 16-line AMLC. This version also supports the SMLC and the 
Inter Processor Controller (IPC) . File sharing between two Prime 300 
or 400 computers is supported with the help of the Pile Access Manager 
(FAM) (available at extra cost) . 
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As described in Section 1, the storage module with a record size of 
1040 words is supported by PRIMOS III. 

CAUTION 

TAP is no longer loaded at 53000 for patching the PRMOSL or 
PRMOSU run file; code is not loaded there. To patch PRIMOS, 
use the command PSD160. PSD160 cannot be given while running 
under control of 64K PRIMOS II. 

Other PRIMOS III Versions 

In the UFD named PRM32, three files: PRIMOS, PRMOSL, and PRMOSU 
comprise the 31-user version of PRIMOS III. The IPC and file sharing 
are not supported in this version; however, the SMLC is supported. To 
run this 31-user version of PRIMOS III, ATTACH to PRM32 and issue the 
command RESUME PRIMOS. 

In the UFD named PRM330, three files: PRIMOS, PRMOSL, and PRMOSU 
comprise the four-user version of PRIMOS III that runs the bit banger 
with the 330 cycle clock. The OPC and file sharing are not suported by 
this version. If desired, the user may move this version to CMDNC0. 

CAUTION 

Be sure to copy all three files to avoid unspecified results. 

The source and command files of PRIMOS III are contained in the UFD 
named PRI300 on Volume 5 of the master disk. PRI300 contains several 
subdirectories with the following contents: 

Subdirectory Name Content 

PRISRC Sources for PRIMOS 

NETSRC Sources for IPC support 

in PRIMOS 

FUFD UFD used for FORTRAN ohiect files 

during system building 

PUFD UFD used for PMA object files 

during system building 

Command Files for System Building 

All command and run files are found in PRI300. The command files to 
build various versions are as follows: 
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Command File System 

C<-16 Builds 15-user version generating 

run files PRIMOS, PRMOSL, PRMOSU, in 
UFD PRI300. 

C<-32 Builds 31-user version generating 

run files with the same name as above. 

C<-330 Builds four-user version of 

PRIMOS III with 330 cycle clock 
generating run files with same names. 

C<-300 Builds four-user version of PRIMOS III 

with 300 cycle clock generating run files 
with same names. 

To build a version of PRIMOS III to support the Gould Printer/Plotter, 
delete the file VERDIM and rename the file GLDDIM to VERDIM and run the 
appropriate command file. 



PRIMOS III SYSTEM INITIALIZATION 

Once the system configurator has installed and appropriately modified 
PRIMOS III in CMDNC0, as explained in the preceding paragraphs, PRIMOS 
III is started from PRIMOS II by the system operator. 

The steps to get PRIMOS III running are: 

1. Turn on processor, disk drive, and all needed peripheral 
devices, and boot load PRIMOS II as explained in Section 1. 

2. To ensure that PRIMOS III is available, enter the command: 
STARTUP Command-disk-number 

if this has not already been done. 

3. To initiate PRIMOS III, issue the command: 
PRIMOS 

Response is: 

PRIMOS REV xx. xx 
yy.y K MEMORY IN USE 
PLEASE ENTER CONFIG 
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At this point, PRIMOS III is not running; but a utility program that 
will bring up PRIMOS III is running. The operator must enter the 
CONFIG command. The erase character, double quote (") may not be used 
to modify input to the CONFIG command. If a mistake is made in the 
CONFIG command, the system does not ask for the command to be retyped; 
instead, it returns to PRIMOS II. The operator must then re-invoke the 
PRIMOS command. 

If the CONFIG command is acceptable, PRIMOS III is brought up and after 
approximately one minute, the introductory message is followed by the 
message : 

PLEASE ENTER DATE 

After the operator inputs the date with the SETIME command, the 
message : 

LOGIN PLEASE 

is printed at user terminals, and users may log in. 

CAUTION 

User terminals will not respond to commands until the SETIME com- 
mand is given by the operator. 

PRIMOS III may be brought up from a command file. The command file to 
bring up PRIMOS III must be named C<-PRMO and must be contained in the 
UFD named CMDNC0. 

If the SMLC or networking (IPC) is to be used, additional parameters 
must be given to the CONFIG command. If the SMLC is to be used, the 
parameter 10/1 must be given. 

Example : 

CONFIG 10 51 50 10/1 

If the IPC is to be used, the CONFIG command line must include the name 
of the system as SYSA or SYSB, depending on whether the slave address 
of the IPC is 1 or 2, respectively. 

Example : 

CONFIG SYSA 10 51 50 

Complete information about CONFIG, SETIME, and other operator commands 
is given in the Interactive Users Guide (MAN 2602) . 
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Sharing Files 



Shariny of files is possible under PRIMOS III and IV. Two or more 
users may be attached to the same UFD at the same time. Furthermore, 
two or more users may have the same file open for reading, and thus may 
be reading the same file at the same time. File interlocks are pro- 
vided, as under PRIMOS II, to prevent one user from reading the file 
while another is writing. This interlock may be modified by the PRIMOS 
III or IV system user. 

File Access Protection 

Under PRIMOS III and IV, a user attached with owner rights (hereafter 
called the owner) has the ability to open his file directories to other 
users, giving restricted access rights. The owner of a file directory 
can declare the access rights that nonowner users have over each file 
File access protection is not available under PRIMOS II. 

The declaration of access can be made on a per-file basis, thus the 
owner has a degree of flexibility in the manner that file access is 
specified. Access rights are separated into three categories: 

Read Access (includes Execute Access) 

Write Access (includes Overwrite Access and Append Access) 

Delete/Truncate Access 

SL^T ri9htS t0 a file are declar ed and specified through the 
PASSWD and PROTECT commands. For details and example, refer to the 
Interactive Users Guide (MAN2602) . 

The owner of a UFD can establish two passwords for access to any file 
in the UFD. An owner password is required by the owner to obtain owner 
privileges, ana a nonowner password (if any) is required to obtain 
nonowner privileges. 

The PROTECT command replaces the existing protection keys on a file. 
It is used by an owner to specify the access rights to be given other 
users of a specific file. 

Bypassing Bad Memory 

PRIMOS III includes features to detect and bypass bad memory chips. 
These features are categorized as follows: 

- On a START, PRIMOS III performs a simple data and parity check 
of all memory locations above 32K. 



- 5 



January 1977 



SECTION 2 MAN2603 



- If memory chips are known to be bad, PRIMOS III can be modified 
(and SAVEd) so as not to use these bad pages (chips) . 

- If the system crashes while running, a self-contained routine 
can be started that tests all available memory to locate any 
memory call that contains incorrect parity. 

Memory Parity 

On a memory parity error, PRIMOS III halts. After determining that a 
memory parity failure has in fact occurred and writing down all the 
registers, the operator must perform a warm start. If any bad pages 
are found, the bad page numbers are printed in octal followed by the 
message : 

PARITY ERROR AT ABOVE PAGES 

STOP, FIX MMAP and PAGMAPS, WARM START 

The operator must stop the machine, fix MMAP and PAGMAPS if possible 
and do another warm start. 



USER IOGIN/L0G0UT 

When a user of the system LOGS IN or LOGS OUT, any existing program 
LOGIN in CMDNC0 is RESUMEd. This program may be custom-written by a 
given installation to perform special LOGIN/LOGOUT functions, such as 
accounting or restricting system access. 

The program is RESUMEd with BREAK inhibited so as to prevent the user 
from exiting LOGIN via Control-P or BREAK. The LOGIN program performs 
a CALL BREAK$ (.FALSE.) before exiting. 

The command line that called LOGIN is available via the library 
subroutine CMREAD. Accounting information is available via the library 
subroutine TIMEAT. The LOGIN program exits via a call to the library 
subroutine EXIT and must not encounter any uncontrolled errors that re- 
sult in EXIT being bypassed. 

Inactivity Timeout 

Users logged in at a terminal but inactive are automatically logged out 
after N inactive minutes, where N is a system configuration parameter. 
A user is considered inactive if the system is waiting for a PRIMOS 
command, or if a user program is waiting tor either terminal input or 
card reader input. The specified number (N) is an installation parame- 
ter. If an inactivity logout occurs, the logout messao^ is preceded by 
the word TIMOUT. 
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The parameter N is set by changing LOUTQM, which is the first variable 
in the common area FIGCOM in subroutine TMAIN. For example, to change 
the inactivity Logout time to 10 minutes, proceed as follows: 

OK, ATTACH CMDNC0 

OK, RESTOR PRIMOS 

OK, START 53000 (This starts TAP) 

GO 

$A 13640 

13640 1750 12 

13641 1 / 

CNTRL P 

QUIT, SAVE PRIMOS LOW ADDR, HI ADDR, STRT ADDR 

OK, 

NOTE 

The above locations may be subject to change without notice. 

SYSTEM CONFIGURATION 

Upon obtaining a master disk from Prime, the system configurator (user) 
must install a PRIMOS III for his installation into CMDNC0. PRIMOS III 
supports 1 to 31 users and a variety of peripheral devices including 
the SMLC. 

Memory Requirements 

A minimum of 48K words of contiguous memory is required to bring up a 
31-user version of PRIMOS III previously described. It is suggested 
that 8K words of memory be available per user. Therefore, a 31-user 
configuration contains at least 256K words of memory. Some 
application-oriented systems may run with less memory. Of course, a 
system may be configured for less than 31 users. For example, an 
installation to run 20 users would require proportionally less memory. 

AMLC Requirements 

Two 16-line AMLC's are required to handle user terminals for 31 users. 
For 23 users, a 16-line AMLC along with an 8-line AMLC may be used. 

Disk Space 

Two platters of a 6.0-million word disk drive (or the equivalent 
partition) are required for paging, if each user is to have a 64K word 
virtual address space. Users 1 through 25 use one platter, and users 
26 through 31 use the other. Alternatively, two 3.0-million word 
partitions of a 30-million word disk may be used. Only one head is 
needed for the storage module. The CONFIG command lines format to 
accomplish this must be given as follows: 
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CONFIG Nuser Pagedevl Coindev [Availm] [Pagdev2] [Namlc] [Nphan] 

For details, refer to the description of the CONFIG command in Section 
7. If Pagedevl is not large enough, a failure to give the parameter 
Pagdev2 causes the message NO PAGEDEV to be printed repetitively at the 
supervisor terminal if a user having a system-assigned user number be- 
tween 26 and 31 attempts to use the system. 

Paging Space Requirements 

For recent versions of PRIMOS III, 32 additional pages are required on 
the paging disk. Some users may require a larger paging space to run 
the same number of users. For all disks except the storage module and 
fixed- head disk, this translates into 64 additional records required 
for paging. When used for paging, the storage module requires one 
record for each page instead of two records per page. 

Modification of Page Maps 

A system configurator may wish to custom-modify the PRIMOS III page 
maps to: 

Run some user with 64K address space and other users with 32K 
address space, 

Run some users on the fixed head disk and others on a moving head 
disk. 

AMLC Driver Configuration 

Many users modify the line speed or group tables for AMLC lines for 
their installations. The position of these tables may change with 
different software revisions and PRIMOS III classes; however, the AMLC 
driver is loaded at 55000 octal for both the 15-user and 31-user 
versions of PRIMOS III. The routines CRDIN and CRDOUT are included in 
the PRIMOS III load package so that serial card reader users may modify 
the AMLC tables to run a serial card reader. 

The AMLC driver is self -con figuring. With the 15-user version of 
PRIMOS III, the driver modifies itself to run either an 8-line or 
16-line AMLC with a device address of either 53 octal or 54 octal. 
Users with an 8-line AMLC do not have to modify the tables to run their 
system configuration. On a 31-user PRIMOS III configuration, the AMLC 
driver modifies itself to run any combination of 8-and 16-line AMLC 
boards, so long as one AMLC has a device address of 54 and the other 
AMLC has a device address of 53. The 31-user PRIMOS III version of the 
AMLC driver also runs with a single AMLC board. 
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A system that consists of two 8-line AMLC boards has user terminals 2 
through 9 connected to the AMLC with a device address of 54 and user 
terminals 18 through 25 connected to the other AMLC. 

Users that modify the AMLC driver group tables must set the tables up 
for their particular AMLC configuration and must not depend on the 
auto-configuration feature of the PRIMOS III systems AMLC driver. 

Through the use of the AMLC command, the configuration word for any 
user terminal AMLC line may be changed. This command is issued at the 
PRIMOS III systems terminal. For further information, refer to the de- 
scription of the AMLC command in this section. 

TAP may be used to modify the AMLC table or make other changes to 
PRIMOS III. The user must exercise caution when patching PRIMOS III 
and remember that PRIMOS III is loaded in 64R mode. 

All AMLC lines are set to run at 1200 baud. System configurators who 
wish to set lines for other speeds must refer to the discussion of 
"Changing Configuration Table". 

A Forced Logout 

An option exists to cause a forced logout if a user hangs up the phone 
on an AMLC line connected to a dataset. This option increases 
security; as another person cannot dial the same number and upon 
connection be logged into PRIMOS III, as happens automatically without 
a forced logout. This option is enabled by setting FIGCOM+3 to a 1. 
FIQCOM stands for configuration common and is part of both TMAIN and 
the PRIMOS III load map. The variable in TMAIN corresponding to 
FIGCOM+3 is DLOGOT. 

Running Split Disk 

The system configurator may wish to use part of a disk surface for 
paging and the rest for the file system. 

On a normal disk, the file system uses space from record to NRECS, 
where NRECS is the number of 448-word records that may be written on 
the disk. On a split disk, NRECS must be specified as something less 
than the maximum; the remainder of the disk space is used for paging 
(see the following schematic diagram) : 

Normal disk: 



I File System NRECS I 

I I 
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Split disk: 



I NRECS | PAGES I 

I File System | Paging j 

The program MAKE must be run to configure a split disk. For further 
information, refer to Secton 6. 

The amount of paging space required is calculated as follows: 

Paging spaces on the moving-head disk is 256 records per user (64K 
address space) plus 352 records for the supervisor. 

Paging space on the fixed head disk is 128 records per user (64K 
address space), plus 176 records for the supervisor. 

For an n-user PRIMOS m configuration, where n is the number of users, 
the amount of paging space needed is: 

PAGES = 256 X n + 352 records on MHD 

PAGES = 128 X n + 176 records on FHD 

Example : 

For a six-user system on a moving head disk: PAGES = 256X6+352=1888 
and NRECS = 6496-2488=4008. This assumes the disk is one platter 
of a 6.0M disk drive. 

To make a split disk, mount a scratch pack on the drive and do the 
following : 

User : MAKE 

Response: PHYSICAL DEVICE = 

User : 52 

Response: 1.5M WORD PACK?: 

User : NO 

Response: SPLIT DISK: 

User : YES 

Response : PAGING RECORDS (DECIMAL) : 
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User: 1888 

Response: DISK FILE-RECORDS PAGE RECORDS (DECIMAL) 
000031 1360 1888 

PARAMETERS OK? 

User : YES 

Response: BAD SPOTS ON DISK: 

User : NO 

Response: VIRGIN DISK? 

User : YES 

Response: VERIFY DISK 

User : YES 

Rsespone: BEGINNING WRITE 
Response: BEGINNING VERIFY 

Response: DISK CREATED (after a while) 

The system configurator must then use the UFDCPY feature of FUTIL to 
copy the UFD's: CMDNC0 and DOS from the master disk. 

NOTE: 

If a split disk is used for paging, it must be used also 
as the command device under PRIMOS III. 

Many systems are shipped with only one disk - a 30M word disk. It is 
suggested that the user not run the 30M word disk as a split disk. 
When a 30NW disk is shipped, it is partitioned into four subdisks: a 
50, 10050, 20050, and 33450. The system configurator should make a 
3.0M word partition for paging if PRIMOS III is for 23 or fewer users, 
or two 3.0M word partitions if PRIMOS III is for 24 or more users. The 
system configurator does this using the command MAKE, to make physical 
device 31050, for example. The rest of the disk must be then be made 
as 1 or more partitions. If it is made as one partition, the disk num- 
ber would be 52450. 



Tables 2-1 and 2-2 provide a guide to disk addresses for system 
configurators. They show disk space required for the supervisor and up 
to 31 users on both 32K and 64K configurations. 



- li January 1977 



SECTION 2 MAN2603 



Changing Configuration Table 



The baud rate for the AMLC configuration can be changed easily by 
modifying the line configuration table for lines 0-6. The line config- 
uration table is identified by a comment in the PRIMOS III source pro- 
gram. The values that may be specified are: 



110 baud: 


XX0033 


300 baud: 


XX0213 


1200 baud: 


XX0313 
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Table 2-1. Disk Space Required for 32K Per User 

MUrv r\-i e?b- A^I^**AC!eee tpur\ r\-i air A^reneQe 



Superv 


'isor 


0-351 




0-175 


1 




352-479 




176-239 


2 




480-607 




240-303 


3 




608-735 




304-367 


4 




736-863 




368-431 


5 




814-991 limit 256K 


432-495 








disk=512 




6 




992-1119 




496-559 


7 




1120-1247 




560-623 


8 




1248-1375 




624-687 


9 




1376-1503 




688-751 


10 




1504-1631 




752-815 


11 




1632-1759 




816-879 


12 




1760-1887 




880-943 


13 




1888-2015 


limit 512K 
disk=1024 


944-1007 


14 




2016-2143 




1008-1072 


15 




2144-2271 






16 




2272-2399 






17 




2400-2527 






18 




2528-2655 






IS 




2656-2783 






20 




2784-2911 






21 




2912-3039 






22 


limit 1.5M 
platter 
= 3248 


3040-3167 






23 




3168-3295 






24 




3296-3423 






25 




3424-3551 






26 




3552-3779 






27 




3780-3907 






28 




3908-4035 






29 




4036-4163 






30 




4164-4291 






31 




4292-4419 






32 




4420-4547 
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User 



Table 2-2. Disk Space Required for 64K Per User 

MHD Disk Addresses FHD Disk Addresses 



Supervisor 


0-351 


0-175 


1 




352-607 


176-303 


2 




608-863 


limit 256K 304-431 


3 




864-1119 


432-559 


4 




1120-1375 


560-687 


5 




1376-1631 


limit 512K 688-815 


6 




1632-1887 


816-1044 


7 




1888-2143 




8 




2144-2399 




9 




2340-2655 




10 




2656-2911 




11 


limit 1.5M 
platter 
= 3245 


2912-3167 




12 




3168-3423 




13 




3424-3779 




14 




3780-4035 




15 




4036-4291 




16 




4292-4547 




17 




4548-4803 




18 




4804-5059 




19 




5060-5315 




20 




5316-5571 




21 




5572-5827 




22 




5828-6083 




23 


limit 3.0M 
platter 
= 4956 


6084-6339 




24 




0-255 pagedev 2 




25 




256-511 




26 




512-767 




27 




768-1023 " 




28 




1024-1279 " 




29 




1280-1535 " 




30 




1536-1791 " 




31 




1792-2047 " 
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Detection of Bad Memory 

If PRIMOS III fails to type its introductory message and halts, it 
usually means that it has detected bad memory. Refer to Section 1 and 
8 for a description of how to recover from the situation. The follow- 
ing example shows a typical operator procedure to bring up PRIMOS III 
for use. After the example, the operator terminal commands issued at 
the start and during the running of PRIMOS III are explained in detail. 
An example startup of PRIMOS III follows: 

OK: STARTUP 50 
OK: PRIMOS 
GO 

PRIMOS REV 11.15 

64. 0K MEMORY IN USE 



PLEASE ENTER CONFIG 

OK, CONFIG 12 51 50 
PLEASE ENTER DATE 
OK, SE -0426 -0905 



WARM RESTART FOR PRIMOS III 

CAUTION 

Do not warm restart blindly. 

If PRIMOS III halts because of an error or because of a machine-check, 
it is usually possible to institute a warm restart as follows: 

1. At the control panel, set the rotary switch to STOP/STEP. 
Press MASTER CLEAR. 

2. START at 1001 for machine check or 1002 for no machine check. 
Store the starting address (e.g., 1001) in Location 7 

and set rotary switch to RUN. 

3. Set START. 

4. At each terminal connected to PRIMOS III at the time of the halt, 
type: 
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followed by a CARRIAGE RETURN. 

CAUTION 

Warm start now runs the memory parity finder before restarting 
PRIMOS and no longer types QUIT, on the system terminal as a re- 
sponse. There is no response to a warm start at the system termi- 
nal. Furthermore, the warm start may run for 20 seconds or more 
before the QUIT, message appears on user terminals. Do not assume 
the warm start has failed without waiting 20 seconds and checking 
to see if QUIT, has failed to appear on a user terminal. 
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OVERVIEW OF PRIMOS IV 
Introduction 

PRIMOS TV consists of three run files in the UFD named CMDNC0 on Volume 
6 of the master disk: PRIMOS, PPMOSL, and PRMOSU. 

WARNING 

The three files with the same names in the UFD named CMDNC0 
on Volume 1 are PRIMOS III for the Prime 300. 

To use PRIMOS, PRMSL, and PRMSU, the files must be copied to the UFD 
named CMDNC0 of the user's command disk. 

PRIMOS is a utility program that preloads the paging device, RESTORES 
the file PRMSU (the upper part of PRIMOS IV) , and RESUMES PRMOSL. 

Configuration Features 

This version of PRIMOS IV supports up to 31 users on the Prime 400 
computer system with one or two 8- or 16-line AMLC controllers. This 
version also supports the SMLC and the Inter Processor Controller 
(IPC) . File sharing between two Prime 300 or 400 computers is 
supported with the help of the File Access Manager (available at extra 
cost). The storage module is supported, with the large record size 
(1024 words) . 

STARTUP OF PRIMOS IV PRIMOS IV is started up from PRIMOS II. To invoke 
PRIMOS IV, give the command: 

PRMOS4 

Typical response is: 

PRIMOS 4 REV 11.32 
XX K MEMORY IN USE 
PLEASE ENTER CONFIG AND DATE 

The operator may enter the CONFIG command DATE exactly as with PRIMOS 
III. The remaining details for entering CONFIG, etc., are the same as 
those described under Bringing PRIMOS III Up in Section 2. 
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PRIMPS IV Versions 

There is one version of PRIMOS IV. The sources and command files of 
PRIMOS IV are in the UFD named PRI400 on Volume 6 of the master disk. 
PRI400 contains subdirectories with the same names as those described 
in Section 2. All command and run files are available in PRI400. The 
command file to build PRIMOS IV is C<-ALL. 

Description of PRIMOS IV Page Maps and Memory Map 

For every user of the system, PRIMOS IV maintains two segment 
descriptor tables. Another set of two segment descriptor tables is 
identical for all users. Currently, Descriptor Tables 0, 1, and 3 are 
identical for any therefore, PRIMOS maintains Descriptor Table 2 for 
each user. These tables can be found ?*■ label DTARL in program TMAIN 
and are locked to physical memory. Each of 31 tables contains room for 
16 entries of 32 bits, allowing for 16 segments per user. The detailed 
format of segment descriptor entries and page map entries may be found 
in Prime 400 Preliminary Systems Reference Manual. Each segment 
descriptor word either has the fault bit set, indicating no page map 
allocated, or points to a page map. The page maps may be found at 
label HMAP in program TMAIN. These page maps are initially set by a 
utility program called MAKM64, which is not part of the PRIMOS memory 
image. Each page map consists of two parts, a 64 16-bit entry page 
table and a 64 16-bit entry disk table. Each page table entry either 
has the fault bit set, indicating page not in memory, or points to one 
of 256 physical pages. Each page is a block of 1024 words of memory. 
Each disk table entry consists of a 2-bit lock field indicating if the 
page is locked to memory, and a 14-bit number that indicates to PRIMOS 
where on the paging disk the corresponding page in the page table is to 
be stored when it is paged out. 

PRIMOS contains 64 page tables that are not locked to memory and are 
themselves paged. 

PRIMOS maintains two tables to keep track of physical memory usage. 
One table (MMAP in TMAIN) contains one word for each physical page, and 
is 377 octal words long. Each physical page may have one of the 
following three states: 

State Meaning of 

-1 Page is not available. An entry in MMAP is set to this 
value if the memory does not exist. It may also be set 
to this value by hand, or it may be set automatically if 
the memory is bad. 

Page is available but not in use (not owned) . 
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>0 Page is in use. In this case, the MMAP entry points to 
the page map entry that is using that physical page. From 

uic cutty duuLcsSf uuc >,cui uci-crj-iiixiic uuc payc luap umi. xo 

currently using the page. The algorithm is: 

page map number = (MMAP entry -1400) /200 

where all numbers are octal and the division is done in octal. 

The second table mainted by PRIMOS contains the user number and segment 
number of each page map. This table, starting at label PTUSEG in 
program TMAIN, contains 66 32-bit entries. After determining which 
page map is used by a particular MMAP entry, one can determine what 
user number and segment number is using that page map by doubling the 
page map number, using that number as an offset into the PTUSEG table 
and reading out the user number and segment number from the table. 

Description of PRIMOS IV Memory Parity Tests 

On a cold start, PRIMOS performs a simple memory test for all memory 
except that used by the memory tester. The test is nondestructive, and 
correct parity is stored in every cell upon completion. Each cell must 
be capable of reading two patterns 052525 and 125252. These tests are 
performed in the COLD START initialization routine (INIT) . 

Upon detecting a bad memory cell, INIT halts. The following 
information is then available: 

register 3 = page-number 

register = 172000 + page displacement 

register 1 = bad bits if 0, one of the two parity bits is bad 

If INIT is continued (by placing function switch in RUN and pushing 
START) , the appropriate physical page is marked unavailable (see MMAP 
description) and the scan continues. If the operator wishes to make 
this page permanently unavailable, he must follow the procedure 
described below. If no bad memory is found, PRIMOS IV prints the 
actual total memory in use as part of its COLD START message. If a bad 
page is found and its number is below 60 octal, the bad page is within 
the supervisor and PRIMOS IV cannot be run until the memory is fixed. 

Permanent Bad Page 

If a page is known to be permanently bad, PRIMOS must be modified and 
saved with the appropriate pages marked 'unavailable'. For example, if 
page number 177 is known to contain a bad cell: 
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MMAP + 177 = 22000 + 177 = 22177 

From ERIMOS II: (operator input underlined) 

OK: ACMDNC0 

OK: REST PRMOS4 

OK: PM 

SA, EA, P, A, B, X, K: 

60 64777 1001 2000 

OK: S 56000 

$ U 22177 777777 

22177 000000 177777 

$ R 7000 

OK: SAVE PRMOS4 60 65777 1001 4000 

OK: 

System Crash (Memory Parity Halt at 31565) 

1. Do not MASTER CLEAR. 

2. Turn on run knob to fetch Y. 

3. Read register 34, which is DSWRMA, the 32-bit address of the 
location that caused the parity halt. This address is virtual if 
caused by the CPU or absolute if caused by a DMX I/O transfer. To 
read absolute register 34, enter 34 in the address, set sense 
switch 1 (SSI) up and SS2 up. Place SS4 up and the address/data 
switch to data. Press the START switch, then record the data in 
the lights as DSWRMA-H. Reset SS4, press the START and record the 
lights as DSWRMA-L. Next, read the high side of register 35 by a 
similar procedure. Record this as DSWSTAT. Verify that bit 15 of 
DSWSTAT is on, indicating a parity error occurred (bit 15 for 4-row 
PROM, bit 3 for 3-row PROM). It bit 10 is on, the parity error 
occurred during Direct Memory (DMx) I/O and location DSWRMA is an 
absolute address. Extract the page number from the address. It 
contists of bits 15 and 16 of DSWRMA-H concatenated with bits 1-6 
of DSWRMA-L. Then refer to the section entitled 'Removing a Bad 
Page' before a WARM START. If DMx was not in progress, the address 
is virtual. Determine the physical address corresponding to that 
virtual address as described in step 4. 

4. Bits 5 and 6 of DSWRMA-H should be 1 and respectively, indicating 
a reference to the user 's Segment Table 2. If these bits are not 
1, 0, go through the rest of the procedure to find the bad physical 
page, but PRIMOS cannot be warm-started (because there was bad 
parity in the supervisor) . 

5. Depending on bits 5 and 6 of DSWRMA-H, determine to access one of 
the descriptor table address registers (DTAR's) as follows: 



REV. A 









MAN2603 


Value 


of 






Bits 


5-6 


Absolute 


Register 


00 


DTAR0 


23 


01 




DTAR1 


22 


10 




DTAR2 


21 


11 




DTAR3 


20 



PRIMOS IV OPERATION 



Access the appropriate DTAR by placing the corresponding register 
number in the address, setting SSI up, SS2 and SS4 down. Fetch the 
contents and read out the data. Double the number read to get a 
pointer to the segment table. If DTAR2 is examined, this pointer 
must point in the range of the STARL table in TMAIN. 

6. Double the segment number in bits 7-16 of DSWRMA-H and add it to 
the address of the segment table determined in step 5. Fetch the 
two-word segment table entry at that address and write down the 
entry. 

7. The first word of the entry contains a pointer to the page table 
for the segment. The second word contains the high-order bits of 
the page table address. Add the page number contained in bits 1-6 
of DSWRMA-L to the page table address to get a 22-bit physical 
pointer to the page table entry. Access the entry and write it 
down. Make sure the access is done with SS4 up, indicating an 
absolute access, 

8. Bits 5-16 of the page map entry indicates the physical page number 
where the memory parity occurred. 

Removing a Bad Page Before a Warm Start 

1. Add the bad page number to 22000 to get a computed entry. Access 
the computed entry and write it down. Replace the entry with a -1, 
which tells PRIMOS the page is not available. 

2. The computed entry points to a page map entry in a page map. 
Determine which page map the entry is in, as explained in the 
previous paragraphs about PRIMOS Memory Map. 

3. If the computed entry address is below 2000 octal, the bad page 
belongs to the supervisor and PRIMOS cannot be warm-started. 

4. Otherwise, the computed entry must contain the virtual address in 
segment of the page map entry. Replace that entry with a 0. 

5. Warm Start by MASTER CLEARing and pushing the START switch twice. 
Then, the system should come up and start running. 
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SECTICN 4 
FIXRAT 



INTRODUCTION 

The external command FIXRAT loads and restarts a maintenance program 
that checks the PRIMOS file integrity on any disk pack. FIXRAT fully 
supports nested UFD's and nested segment directories, and may be run 
from a command file. 



FIXRAT DESCRIPTION 

The external command FIXRAT runs under PRIMOS; it loads and starts a 
maintenance program that checks the file integrity. Before reading 
this document, the user should read a description of the file structure 
found in the File System Users Guide (MAN 2604) . Existing PRIMOS users 
should also read this guide for a description of segment directories, 
nested directories, and FIXRAT printout options. 

FIXRAT reads every record in every file, UFD, and segment directory, 
and checks that information in each record header is consistent with 
both record headers in the rest of the file and with the file directory 
that contains the record. 

Any inconsistencies generate an error message. FIXRAT also builds a 
record available table (RAT) from the existing file structure and 
compares it to the DSKRAT file for agreement. If discrepancies are 
found, FIXRAT prints an error message. 

If requested, FIXRAT will not only check the file structure but also 
repair pointers (if possible) , truncate or delete defective files, and 
generate a corrected DSKRAT file. Up to two repetitions of FIXRAT may 
be necessary to repair a damaged file structure. The recommended 
procedure is to repeat FIXRAT until an error-free printout is obtained. 

FIXRAT must be run whenever there is reason to expect that the file 
structure is damaged; for example, if a pronram being debugged runs 
wild and writes over part of PRIMOS II. Until the user gains 
experience with the system, FIXRAT should be at the close of every 
operating session. Never attempt to run FIXRAT after a COPY has 
aborted . 

The suggested procedure to maintain a disk pack is to run FIXRAT every 
morning and, if no errors occur, to copy the pack onto a daily backup 
pack. If any files are truncated or deleted from the pack, they are 
copied from the existing daily backup disk, to the disk pack. Then 
this new disk pack is copied to an updated daily loading disk. The 
owners of the bad files must be notified that those files have been 
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copied from the backup and any modifications to those files may have 
been lost. 

FIXRAT and Disks 

FIXRAT will maintain files on a Y disk, including the storage module, 
and handles both 448-word and 1040-word records. Urrfer *D0S16, only 
FIXRAT is limited to 3-million word disks; a command file cannot be 
used in this case to run FIXRAT. 

Running FIXRAT 

The command is: 

FIXRAT [OPTIONS] 

If the word OPTIONS is included, FIXRAT requests printout options. 
Otherwise, FIXRAT prints the name and number of records used (in 
decimal) in the MFD and in each directory in the MFD. When entered, 
FIXRAT asks the question: 

FIX DISK ? 

If the answer is YES .CR. , FIXRAT truncates or deletes defective files 
and generates a corrected DSKRAT file, in addition to checking the file 
structure and repairing all file structure errors. FIXRAT then asks 
the question: 

PHYSICAL DISK DRIVE = 

The user types in octal the physical disk drive on which FIXRAT is to 
be run, followed by .CR. ; FIXRAT then prints the disk pack identifica- 
tion (which is the name of the DSKRAT) and begins processing the file 
structures. The DSKRAT is always the first file in the disk pack ID. 

Figure 4-1 is a sample PRIMOS file structure. 

The file structure on any disk pack is a tree structure where the MFD 
is the root or trunk of the tree, the links between directories and 
files or subdirectories are branches, and the directories and files are 
nodes. 

A directory tree consists of all files and subdirectories that have 
their root in that directory. In Figure 4-1, the directory tree for 
UFD1 is circled. The level of a file is the depth of that file in the 
tree. For example, as shown in Figure 4-1, the MFD is at level 1 in 
the tree, UFDl is at level 2 in the tree, and FILEC is at level 4. 

FIXRAT traverses the file structure, as shown by the snaked line in 
Figure 4-2, generating typeout at the various points below. 
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FIXRAT 



r 



DSKRAT 



±. 



IBOOT 



S 



y 



/r 



/ 



/ 



/ 



/ 



\ 



\ 



\ 



SUFD11 



V 



FILEA 



root 



MFD 



3L 



UFDl 



branch 



mode Ss >. 



\ 



\ 



1 



SUFD12 



1 



FILEB 



/ 



directory tree ' 



/ 



y 



1 



UFD2 

— t 



t 



SUFD21 



level 1 
level 2 



level 3 



FILE C 



level 4 



Figure 4-1. Sample File Structure 



The terminal output appears as follows for the above file structure: 

BEGIN MFD 
BEGIN UFD 
BEGIN SUFD11 
END SUFD11 10 
BEGIN SUFD12 
END SUFD12 10 
END UFDl 21 
BEGIN UFD2 
BEGIN SUFD21 
END SUFD21 10 
END UFD2 11 
END MFD 35 
RECORDS USED = 35 
RECORDS LEFT = 6223 
DSKRM" OK 
OK, 
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BEGIN MFD 



END MFD 




DSKRAT 



MFD 



BOOT 



UFD 1 



BEGIN UFD 1 



END 
UFD 1 



BEGIN 
UFD 2 



BEGIN f 












SUFD11 / 






END 








SUFD 11 


SUFD 11 


SUFD 12 








* ) BEGI 
I SUFC 


N 
t 12 






FILEA 




FILEB 



END 

SUFD 12 




UFD 2 



END 
UFD 2 



BEGIN 
SUFD 21 



SUFD 21 



END 
SUFD 21 




Figure 4-2. Typical FIXRAT Traverse of File Structure 



FIXRAT prints the word BEGIN followed by the directory name when 
beginning processing of a directory tree. On leaving a directory tree, 
FIXRAT prints END Directoryname followed by the number of physical re- 
cords (in decimal) used by all files and directories in the directory 
tree. In the above example, this is the number following MFD (35). 
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FIXRAT indents the printed output one space for each level down in the 
tree in which the directory is located. This indented format makes it 
easy to unuetsuciiiu luc leiatxuiisnx^/ ui cra^n uxj.e^»_wj.jf -<-<-- u£ ^•.i**.*. 
directories in the tree. To prevent excessive output, FIXRAT as a 
default prints out only directory names at levels 1 and 2 in the tree. 
Unless OPTIONS is specified, FIXRAT processing of the tree shown in 
Figure 4-1 generates the following default output: 

BEGIN MFD 

BEGIN UFD1 

END UFD1 21 

BEGIN UFD2 

END UFD2 11 
END MFD 35 
RECORDS USED = 35 
RECORDS LEFT = 6223 
DSKRAT OK 
OK, 

If the command FIXRAT OPTIONS is given, FIXRAT asks the question FIX 
DISK ? and PHYSICAL DISK DRIVE =, as before, and also asks: 

TYPE DIRECTORIES TO LEVEL = 

The user must type an octal number corresponding to the lowest level in 
the tree structure in which directory names are to be printed. The 
following table describes the output: 

LEVEL Output 

blank All directories 

1 MFD only (level 1 directory) 

2 MFD and all directories in MFD file 
(level 2 directories) 

3 All output for level 2 and all directories 
at level 3 (level 3 directories) 

etc . etc . 

FIXRAT will then ask: 

TYPE FILE NAMES ? 

If the answer is YES followed by .CR. , FIXRAT prints all filenames in 
all directories, indented appropriately. This option is useful for 
listing the contents of a disk. Note that, unless the user requests 
suppression of directory name output by answering the TYPE DIRECTORIES 
to LEVEL = question with the parameter one, directories are printed 
three times; twice as directories and once as files. 
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FIXRAT will then ask: 

TYPE FILE CHAINS ? 

If the answer is YES, followed by .CR. , FIXRAT prints the disk address 
of all records in all files on the disk. All files consist of one or 
more records chained together by pointers. This option is useful to 
see how files are scattered on a disk. FIXRAT begins processing the 
disk after this point, as it would if the OPTIONS parameter was not 
specified. 

Following the file structure analysis printout, FIXRAT prints the 
number of records used and the number of records left on the pack for 
file system use. Finally, FIXRAT compares a record avail- ability 
table (built from the existing file structure) against the DSKRAT. If 
they match, FIXRAT types DSKRAT OK and exits to PRIMOS. If they do not 
match, FIXRAT types DSKRAT FILE DIRECTORIES MISMATCH. 

FIXRAT Output Example 

The following is sample FIXRAT output generated after all questions 
have been answered: 

DISK PACK ID IS DSKRAT 



BEGIN MFD 




BEGIN CMDNC0 




END CMDNCO 


000021 


BEGIN DOS 




END DOS 


000011 


END MFD 


000035 


RECORDS USED = 


= 000035 


RECORDS LEFT = 


= 006223 


DSKRAT OK 




OK: 





The first line prints the disk pack identification as the name of the 
disk. Generally, this name is DSKRAT. 

The next section of output concerns FIXRAT examining the file structure 
on the disk for consistency. This sample output is generated from a 
disk that contains only two directories, CMDNC0 and DOS, in the MFD. 
If either of these directories contains subfile directories, FIXRAT 
traces the nested directory structure but does not print the name of 
the subfile directories. Each directory is printed twice; following 
the word BEGIN when FIXRAT enters the directory, and following the word 
END when FIXRAT is finished processing the directory and any subfile 
directories nested within it. Directories that are files in the MFD 
are indented one space when typed, to show the nested structure. 
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Following the directory name, FIXRAT prints a number that is the number 
of records used in the directory plus all files nested within that dir- 
ectory. Since all files on a pack are nested within the MFD, the 
number of records used in the MFD always matches the number of records 
used on the disk pack. 

Following the printing of the file structure analysis, FIXRAT prints 
the number of records used on the pack and the number of records left 
on the pack for file system use. 

Finally, FIXRAT compares a record availability table (RAT) built from 
the existing file structure against the DSKRAT. In the preceding 
example, they match and FIXRAT prints: 

DSKRAT OK 
and exits to PRIMOS. 
If the RAT and DSKRAT totals do not match, FIXRAT prints: 

DSKRAT, FILE DIRECTORIES MISMATCH 

If the user typed YES to the question FIX DISK ?, FIXRAT repairs the 
DSKRAT and types: 

DSKRAT FIXED 

then exits to PRIMOS. Otherwise, FIXRAT asks the user: FIX DISK? If 
the user answers YES, .CR. the DSKRAT is repaired. This option is 
useful if there are no file structure errors but there is a bad DSKRAT. 

Broken File Structure Messages 

When FIXRAT detects a problem in the file structure, it prints an error 
in the following format: 

reason for error 

FILE - filename BAD RECORD = octal record address. 

DIRECTORY PATH = list of directories 

FILE DELETED, FILE TRUNCATED or blank 

The directory path is the list of nested file directories needed to get 
from the MFD to the bad file. For example, if FILEC in Figure 4-2 was 
broken, the directory path would be MFD, UFD2, SUFD21. Because all 
treenames have the MFD as a root, "MFD" is not printed as part of the 
path. 
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After printing the directory path, FIXRAT prints how it disposed of the 
bad files. If the FIX DISK question was answered NO, FIXRAT does noth- 
ing to the file, and therefore prints nothing. Otherwise, FIXRAT 
either truncates the file before the bad record and prints FILE 
TRUNCATED, or, if no part of the file can be saved, removes the file 
directory entry from a UFD, or zeroes the entry in a segment directory 
and prints FILE DELETED. 

Segment Directories 

A segment directory may contain references to files, other segment 
directories and User File Directories (UFD) . The distinction between a 
UFD and a segment directory is that entries in a UFD are referenced by 
name and those in a segment directory by position. Recall that each 
entry in a UFD consists of a one-word disk address that is the beginn- 
ing record address of the file, followed by a six-letter name and two 
spare words. Refer to the File System User Guide (MAN 2604). In a 
segment directory, FIXRAT prints the absolute position of the file in 
the segment directory as a decimal number-pair (record number, word 
number). For example, the first entry in a segment directory is 
printed as (0, 0), the second entry as (0, 1), the 440th as (0, 440), 
and the 441st entry as (1, 0). Note that, as with user file 
directories, identically named files in different segment directories 
represent unique files. 

If FIXRAT is requested to FIX DISK and detects a bad file, it either 
truncates or deletes the file, depending on where in the file a problem 
is detected. If FIXRAT deletes a file, the action taken depends on the 
type of directory into which the file is entered. If the directory is 
a UFD, FIXRAT removes the entry from the directory in an action similar 
to that of the DELETE command. If the directory is a segment direc- 
tory, FIXRAT sets the entry to zero. On the next pass, FIXRAT skips 
the zero entry. The convention, then, is that a zero in a segment dir- 
ectory represents a null file. 

Disks With Bad spots 

FIXRAT handles disks with badspots (Refer to MAKE, Section 5). In 
checking integrity of the DSKRAT, the file BADSPT in the MFD is also 
examined by FIXRAT. The file, BADSPT, contains information about bad- 
spots on the disk, i.e., the record addresses of badspots on the disk. 
Disk records that have badspots are not available for file system use, 
and FIXRAT must take this factor into account when fixing a disk or 
checking file integrity. 

The file BADSPT may not be present on the disk, or it may be empty. In 
both cases, FIXRAT need perform no badspot handling. 

The format of the file BADSPT in the MFD is described in Section 6. If 
the format of the file BADSPT is incorrect, FIXRAT prints the message: 
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BAD BADSPT FILE, IGNORED 
Otherwise , FIXRAT types: 

BADSPT FILE HAS ENTRIES = No. 

where No. is the number of badspots. 

When FIXRAT is finished processing the disk, if there are any badspots 
that affect the current disk or partition, FIXRAT prints: 

BADSPT RECORDS LOST = No. 



PITFALLS 

Bad BOOT 

If the BOOT file in the MFD is accidentally deleted or broken, PRIMOS 
will allocate record number to the next new file. FIXRAT will 
complain if any file except the BOOT in the MFD contains record 0. The 
message given is: 

BAD DISK ADDRESS BAD RECORD = 

If this occurs, RESTOR from a good MFD and SAVE the BOOT into the MFD 
before doing anything else. 

Directory Nesting Limit 

FIXRAT will trace nesting of directories to a depth of 100 levels only. 

Writing Into Directories 

Because directories may be nested, the possibility of accidentally 
writing bad data into directories is increased. A bad file structure 
will be detected by FIXRAT. To minimize this possibility, it is 
suggested that users preface all except those in the MFD by U_ and all 
segment directories by S_. 

Deleting Directories 

Delete all files contained in the directory before deleting a UFD or 
segment directory; otherwise, the records used by the files in the 
directory will not be returned to the DSKRAT. When the next FIXRAT is 
run, the message DSKRAT, FILE DIRECTORIES MISMATCH is given, and the 
records of files not deleted explicitly will not be recovered for use 
until the next FIXRAT. 
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FIXRAT ERROR MESSAGES 

This section lists all error messages generated by FIXRAT and gives an 
expanded explanation of them. The user should be familiar with the 
details of the file structure. Error messages are of the form: 

reason for error 

FILE = filename BAD RECORD = octal number 

DIRECTORY PATH = list of nested directories 
Description of Messages 
Message Meaning 



DSKRAT BAD 



This message is obtained if the DSKRAT 
file contains any bad record pointers, 
the DSKRAT data header word is not 5, or 
the words in the DSKRAT file does not 
match (NRECS+15)/16-+5. If the DSKRAT is 
BAD, FIXRAT reconstructs it, using 
parameters typed by the user in response 
to the following questions. If the user 
types CARRIAGE RETURN to any of the 
questions, default values are used. 
The questions are: 

INPUT DECIMAL RECORD SIZE 

INPUT DECIMAL FILE SPACE RECORD COUNT 



BAD DISK ADDRESS 



INPUT DECIMAL CYLINDERS = 
INPUT DECIMAL HEADS = 

The default values for the particular disk 
model are used by FIXRAT if the user does 
not specify them and type .CR instead. 
FIXRAT prints the default or the specified 
values back to the user for verification 
then asks "OK"?. If the answer is YES, 
FIXRAT repairs the DSKRAT and continues, 
or else it requests the parameters again. 
Refer to Section 2 for tables of disks 
and values. 

A pointer to a disk record is out 
range. Acceptable range is between 
1 and NRECS -1, where NRECS is the number 
of records available for file system use. 
NRECS is stored in the DSKRAT data header. 
A record address of is acceptable only 
for the disk bootstrap loader file BOOT in 
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BAD RECORD ID 



the MFD. 

The first word of a record contains a 
number unequal to its record address. This 
message may be preceded by 10 disk error 
messages because this problem could 
indicate a disk drive problem. 

FIXRAT has difficulty determining whether 
the error is a disk drive error or a 
broken file. The disk driver retries 
10 times, producing 10 disk error 
messages and then returns to FIXRAT, 
which print? the message BAD RECORD ID. 
Be sure to allow FIXRAT 10 disk error 
messages before assuming there is 
disk drive trouble. Refer to the 
description of an Unrecovered Read 
error in this section. 



BRA POINTER MISMATCH 



The second word of the second record 
(or greater) of a file does not point 
to the beginning record of the file. 



FATHER POINTER MISMATCH 



BACK POINTER MISMATCH 



The second word of the first record 
of a file does not point to the 
beginning record address of its file 
directory. 

The back pointer of a record does 

not point to the previous record of the 

file. If the current record is the first 

record of a file, the back point is not 0. 

(For the storage module, 

count is word 4 of the record.) 



BAD WORD COUNT 



The data word count of a record 
is not between and 440. A word 
count of indicates an empty record. 



NOTE: 

For the storage module, the data word count 
is word 5 of the record. 



BAD FILE TYPE 



The data word count for the storage 
module, word 6, of the first record of a 
file is not between and 4. 
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TWO FILES POINT 
TO SAME RECORD 



Two files point to the same first 
record; FIXRAT prints the name of 
the second file only. This error may 
occur if the DSKRAT is changed by a user 
overwriting PRIMOS II, or if the 
BADSPT file is changed after first 
running FIXRAT. Records already 
have been erroneously made 
available to new files. 



BAD DAM POINTER 



UFD LONGER THAN 
RECORD 



A DAM data file or DAM segment 
directory has a bad index in the first 
record of the file, and the nth index of 
the file does not point to the nth 
record of the file for all records 
of the file. This error is repaired 
by FIXRAT. 

A UFD is longer than one record. 
PRIMOS expects all UFD's to be only 
one record long. 



BAD UFD HEADER 



When the storage module is present, data 
word 1 of a UFD file does not contain 
8 (decimal) , the first word of a 
UFD header. 



DIRECTORIES NESTED 
TOO DEEP 



Directories may be nested to a 
depth of 100 levels. FIXRAT 
cannot follow the directory tree 
because the user has nested directories 
to more than 100 levels. 



BAD STRUCTURE MESSAGES 



FILE = MFD BAD RECORD = 7 
DIRECTORY PATH = MFD 
FIXRAT ABORTED 

A MFD has been altered and damaged. 
The best action to take is to copy the 
backup disk onto the "daily user disk" 
and continue. 

DSKRAT NOT IN MFD 
FIXRAT ABORTED 

The DSKRAT has been accidentally deleted 
from the MFD. Suggested action 
is same as for a damaged MFD. 



REV. A 



- 12 



MAN2603 



FIXRAT 



RECORD READ OK NOW CHECKS BAD 
POSSIBLE DRIVER ERROR, FIXRAT ABORTED 



Suggested action is to run the disk diagnostic on a 
scratch disk pack. 



DIRECTORY RECORD READ OK NOW CHECKS BAD 
POSSIBLE DRIVE ERROR, FIXRAT ABORTED 



Suggested action is same as suggested in the previous 
paragraph. 



CHECK FOR MFD 



FIXRAT checks that the first three entries 
in the MFD are DSKRAT, MFD, and BOOT. 
The DSKRAT may have any name and the name 
is used on the disk pack ID 
(identification) . The error messages 
that may arise as a result of one 
of these entries being missing are: 



DSKRAT NOT IN MFD, REPLACE IT? 

MFD NOT IN MFD, REPLACE IT? 

BOOT NOT IN MFD, REPLACE IT? 

MFD HAS BAD NAME, REPLACE? 

If there is a YES (followed by CR) 

response to each of these questions, 

the specified action asked in the message 

is performed. The user must neither 

delete nor alter the DSKRAT, MFD, 

or BOOT, since these are system files 

used by PRIMOS. 

FIXRAT and 30-Million Word Disk 

FIXRAT supports the 30-million word disk (storage module) . If the 
30-million word disk is treated as a single disk device (no partition- 
ing) , the disk nunbers 0, 1, 2, 3, attached to the controller are 5252, 
5253, 5254, and 5256, respectively. If the disk is partitioned, disk 
numbers include head- offset and number-of -heads information. If the 
user gives an incorrect disk number, one of the following messages is 
printed at the terminal: 

DEVICE, DSKRAT DIFFER IN HEAD COUNT. ABORT? 

DISK READ ERROR with status of 177777 
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UNRECOVERED DISK READ ERROR 



On an unrecovered disk read error, the track and head of the bad record 
are reported. If desired, this badspot record location may be manually 
added to the BADSPT file, using the MAKE command. Normally, 
unrecovered read errors indicate a malfunctioning or misaligned disk 
drive, a head crash, or a bad disk pack. An unrecovered read error may 
also indicate a pack that has badspots that were not entered into the 
BADSPT file during the last MAKE operation. When an unrecovered read 
error occurs, FIXRAT must be rerun after the BADSPT file is modified by 
MAKE. When FIXRAT is rerun as a result of the unrecovered read error 
recovery procedure described here, multiple errors of the form: 

TWO FILES POINT TO SAME RECORD 

may occur. These errors result because a badspot may affect up to 
eight records belonging to multiple files. 



EXAMPLE OF FIXRAT 

The following is an example of FIXRAT run under PRIMOS II with the 
optional argument, OPTIONS: 



PRIMOS II REV 11.0 07/15/76 (AT 070000) 



OK: STARTUP 30 

OK: FIXRAT OPTIONS 

GO 

REV. 11. 00 

FIX DISK? YES 

PHYSICAL DISK = 30 

TYPE DIRECTORIES TO LEVEL = 3 

TYPE FILES NAMES? YES 

TYPE FILE CHAINS? YES 



DISK PACK ID IS MD11V1 
BEGIN MFD 
000001 
BEGIN MFD 

BEGOM ,D11?BEGIN MD11V1 
000002 

BEGIN BOOT 
000000 

BEGIN CMDNC0 
000003 

BEGIN CMDNC0 
BEGIN MCG 
000006 
000011 
000014 
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BEGIN NUMBER 
,BR?,BER?.BR 000017 
000005 
000010 
000013 
000016 
000007 
000012 

BEGIN BASINP 
000015 
000020 

BEGIN SIZE 
000023 
000026 
000031 

BEGIN FILVER 
000034 
PHYSICAL DEV=30 

PRIMOS II REV 11.0 07/15/76 (AT 070000) 



OK: STARTUP 30 

OK: FIXRAT 

GO 

REV. 11.00 

FIX DISK? 30 

PHYSICAL DEV=30 

PRIMOS II REV 11.0 07/15/76 (AT 070000) 



OK: STARTUP 30 

OK: FIXRAT OPTIONS 

GO 

REV. 11.00 

FIX DISK? YES 

PHYSICAL DISK = 30 
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OVERVIEW 

MAKE creates a disk for any disk or storage module supported by PRIMOS. 
MAKE may run from a command file under any version of PRIMOS. Under 
PRIMOS III or IV, the disk to be created by the MAKE command must be 
ASSIGNed before MAKE is invoked. MAKE must be used to create 
partitions and disks, including paging and user disks. MAKE creates a 
PRIMOS disk that has the following: 

DSKRAT 
MFD 
BOOT 
DOS 

CMDNC0 

The MAKE program writes the bootstrap (BOOT) into Record of the disk. 
MAKE places the proper length Record BOOT on the disk being formatted 
by MAKE. 



RUNNING MAKE 

To run MAKE, type the command: 

MAKE 
The response is: 

PHYSICAL DISK 

The user must then type the number of the physical disk to be created. 
All user-typed responses must be followed by a carriage return. This 
disk must not be connected to PRIMOS by the STARTUP command. Possible 
disk numbers are listed in Section 1; a summary of possible disk 
numbers is given in the description of the COPY command. 

It is recommended that when running MAKE under PRIMOS II, all running 
disks be write-pro tec ted except the disk to be created by MAKE. Under 
PRIMOS III and IV, it is recommended that only the disk to be created 
by MAKE be ASSIGNed to the terminal. 

MAKE computes the number of records on the disk pack from the disk 
number. In case of ambiguity, MAKE asks resolving questions such as: 
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1.5M WORD PACK? 



MAKE then asks: 

SPLIT DISK? 

The user responds by typing YES followed by carriage return at the 
terminal, if part of the disk is to be used for paging (for an example, 
refer to Section 21. If YES, MAKE then asks: 

PAGING RECORDS (DECIMAL) 



The user responds by typing the number of records to be used for 
paging. This number is determined from the number of users to be run 
under PRIMOS III or IV. Refer to Section 2 for details of this 
calculation. MAKE then responds by printing the disk number, file 
records, and paging records at the terminal. Then, MAKE asks the user 
if the parameters are OK. The following table of file records is a 
guide to help the user verify that the parameter input was correct. 



Disk 



Decimal Records 



Diskette 460 

1.5 million word disk 3248 

3.0 million word pack 6496 

30 million word disk 64960 

128 thousand word fixed head disk (32 track) 256 

256 thousand word fixed head disk (64 track) 524 

512 thousand word fixed head disk (128 track) 1024 

1025 thousand word fixed head disk (256 track) 4096 



If the 30-million word disk is partitioned, 
may be specified as shown in Table 5-1. 



other RECORDS parameters 



Table 5-1. RECORDS Parameters for 30-Million Wbrd Disk 





Device Address 23 


Device Address 21 




Partition 


Disk Number 


Disk Number. 




RECORDS 


2 head (default) 


XX025X 


XX005X 


6496 


2 head (explicit) 


XX065X 


XX045X 


6496 


4 head 


XX125X 


XX105X 


12992 




6 head 


XX165X 


XX145X 


19488 




8 head 


XX225X 


XX205X 


25984 




10 head 


XX265X 


XX245X 


32480 




12 head 


XX325X 


XX305X 


38976 




14 head 


XX365X 


XX345X 


45472 




16 head 


XX425X 


XX405X 


51968 




18 head 


XX465X 


XX445X 


58464 




20 head 


XX525X 


XX505X 


64960 
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In Table 5-1, the x's represent octal digits that must be set 
appropriately. The leftmost X's specify head offset, and rightmost X 
specifies one of four possible drives connected to the controller. 

MAKE also handles the storage module disk, using disk numbers as 
described in Section 1. 

For a 128 thousand word fixed-head disk, a diskette, or a 1.5 million 
word disk pack, the user can type CARRIAGE RETURN and MAKE defaults to 
the correct number of records for that disk. MAKE echoes the user 
input as follows: 

DEVICE NUM RECORD COUNT where <number> is 
<number> <nuraber> one of the above 



octal numbers 



OK? 



If the number is correct, type YES in response to the OK? query 

followed by CARRIAGE RETURN. If not, type NO followed by CARRIAGE 

RETURN, and MAKE requests the input again. After the number of records 

are specified, MAKE then asks the question: 

BADSPOTS ON DISK? 

Badspots are part of a disk pack that cannot hold data. On 30-million 
word disk packs, this information is recorded on the inside bottom 
cover in the form of a list of pairs of numbers. These pairs (track 
number, head number) represent parts of the disk determined by the disk 
manufacturer to be probable badspots. If the list exists, the user 
must type YES response to the BADSPOT question. MAKE then prints: 

TRACK= 

The user responds by typing the track of the first badspot. MAKE then 
prints: 

HEAD= 

The user responds by typing the head of the first badspot. This 
dialogue between MAKE and the user continues. Thus, the user may 
record the track and head of all badspots on a given disk. The TRACK, 
HEAD pair 0, 9 terminates input of badspots. MAKE then prints a list 
of the badspot HEAD and TRACK numbers at the terminal and asks: 

PARAMETERS OK? 

If they are OK, the user types YES. At this point, MAKE writes a file 
containing the badspot information in the MFD with the filename BADSPT. 
The file named BADSPOT is used by the utility commands FIXRAT and COPY. 
MAKE also initializes the DSKRAT file to ensure that badspot records 
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are not available for file system use. 

If there are no badspots on the disk, the user responds by typing NO 
when the query BADSPOTS ON DISK? is printed by MAKE, and no BADSPT 
file is created. MAKE then asks the question: 

VIRGIN DISK? 

If the user answers YES, followed by CARRIAGE RETURN, MAKE writes the 
first records (n=RECORD-COUNT) of the disk. The first word of each 
record is set to the record address; record size is 448 words. This 
action also writes a valid hardware checksum tor each record. If the 
user answers NO followed by CARRIAGE RETURN, MAKE does not initialize 
the records. The records need not be initialized if all the records 
have been initialized by a previous run of MAKE. However, it is 
strongly recommended that the user answer YES to the VIRGIN DISK ? 
question at each invocation of MAKE. 

If the disk is a storage module, upon a request to MAKE a disk with the 
VIRGIN DISK question answered YES, MAKE formats the disk or partition; 
and the MAKE writes all records on the disk or partition to generate 
correct checksums. 

If the user desires to make a split (partitioned) disk, the recommended 
procedure is to first run MAKE with the SPLIT-DISK question answered 
NO, then rerun MAKE with the SPLIT DISK? question answered YES. The 
reason for this action is to write correct checksums on the entire disk 
initially, not just the file system part of the disk. This action is 
also important if it is desired to copy the split disk at a later time 
using the COPY command. After the VIRGIN DISK query, MAKE then asks 
the question: 

VERIFY DISK? 

If the user types YES, MAKE reads every record in the file system part 
of the disk to verify that each record can be read. 



PITFALLS 

During the reading and writing of all records, MAKE displays the record 
number it is processing in the DATA lights. When done, MAKE prints 
DISK CREATED and returns to the operating system, which types OK,. If 
any of the badspots affected the current partition or platter, the 
message: LOST RECORDS is printed. If any disk write errors occur, 
MAKE retries nine times. Each error results in an error message of the 
form: 

DISK WT ERROR device # PRIMOS record # Status 
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If the write is not successful after ten tries, MAKE aborts, prints the 
message JJNRECOVERED ERROR, and returns to the operating system. If a 
uiSK-Nui-KEADY status is detected, a single disk error message is typed 
with a status of 177776. The software then retries to write, waiting 
for the disk to become ready. If a read is not successful, MAKE gives 
up and prints: 

READ ERROR, RECORD - record # 

If the BADSPT file exists, MAKE then asks: 

ADD TO BADSPT FILE? 

If the user responds by typing YES, MAKE prints the track and head of 
the badspot and modifies the BADSPT file and DSKRAT appropriately. If 
the user runs MAKE, then answers YES to VIRGIN DISK? and VERIFY DISK?, 
it is possible to find out immediately if there is any problem in the 
file structure part of the disk pack. 

After MAKE is run, the user must use FUTIL to copy *D0S16, *DOS24, and 
*DOS32 from UFD DOS on a master disk to UFD DOS on the newly created 
disk. The BOOT file in the MFD that is read from the disk by the 
control panel boot expects these files to be in UFD DOS in order to 
bootload PRIMOS using the newly created disk pack. The user must also 
use FUTIL to copy DOSEXT from UFD CMDNC0 on a master disk to UFD CMDNC0 
on the newly created disk. 

It may be desirable to use part of a disk pack for the file structure 
and part for the paging device under PRIMOS III and IV. The user must 
follow the directions given in Section 1. 

Decescription of BADSPT 

The BADSPT file is a saved memory image. The file may be examined and 
modified by RESTORing it and referencing the file with the debugging 
command TAP. BADSPT is restored into consecutive memory locations 
starting at location 1000 octal. A BADSPT file is created only if 
badspots exist; this can be verified by issuing the PM command 
following the command line: 

RESTOR BADSPT 

Pairs off numbers, starting at 1000, constitute the track and head 
number of each badspot on the disk. The file BADSPT can be no longer 
than one record. Thus, BADSPT records a maximum of 215 badspots. To 
add a badspot to the BADSPT file, place the track and head data in 
locations EA+1 and EA+2 (EA is the second parameter printed by the PM 
command); then, give the command: 

SAVE BADSPT 1000 EA+2 
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The BADSPT file may be used in conjunction with disks other than the 

30-million word disk, with the exception of fixed head disks and 

diskettes. MAKE handles badspots on the storage module disk in the 
same manner as it does on the 30-million word disk. 

CAUTION 

The BADSPT file must not be deleted, or overwritten, or copied TO. 
This file is used by FIXRAT and COPY to process badspots. 



BUILDING MAKE 

If the system is being bootstrapped, or if the storage module is to b 
be formatted, it may be necessary to build MAKE by running the command 
file C_MAKE before formatting any disks. During trie process of 
building MAKE using the command file C_MAKE, the file *BOOT is created. 
*BCOT is an image of the record bootstrap, as it would appear on the 
storage module. This run file may be used to place the storage module 
bootstrap (See Appendix B) on old disk volumes other than storage 
modules without rerunning MAKE. *B0OT may also be used to change the 
start-up parameters for the supervisor terminal. 

To save *BOOT as BOOT, perform the following: 

RESTORE *BOOT 

SAVE BOOT (with the following parameters) 



Parameter 


448-record 








1040-word record 


SA 


3011 








3011 


EA 


3667 








3771 


P 











1 


A 














Bx 


Controller < 


Control 


Wd 




KEYS 


SOC Control 


WD 


1 








SOC Control 


WD 


2 







The proper SAVE command for all disks except the storage module is: 

SAVE BOOT 3011 3667 110 27 74000 
The SAVE command for the storage module is: 

SAVE BOOT 3011 3771 1 110 27 74000 



*BOOT 

An image of *BOOT is stored as part of the program MAKE in the COMMON 
BO0T1. The sirst nine decimal words of the COMMON correspond to the 
SAVE parameters given in the previous paragraphs. The serial interface 
controller contarol word is then at location: ( LOC( (B0OTl)+4) . The 
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procedure for changing MAKE to create bootstraps (See Appendix B) for 
systems which do not use TTY as the supervisor terminal is: 

Build MAKE user command file C_MAKE to get the value 
of IOC (B00T1) from the load map 

RESTORE MAKE 

EM 

Use PSD or TAP to insert new initial control words 

SAVE MAKE 'use original parameters) 

The serial interface controller control words (Port 1) are: 

Serial Interface SOC Fort Sel SOC Character 
Speed (Baud) Control Words and Speed Definition 



110 


110 


27 


74000 


300 


1010 


76 


34000 


1200 


2010 


373 


34000 


9600 


3410 


3735 


34000 
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COPY 



OVERVIEW 

COPY is an external command that copies and verifies a disk. COPY 
copies any disk to any other disk under PRIMOS . Under PRIMOS III or 
IV, both disks must be ASSIGNed before invoking COPY. 



RUNNING COPY 

After the user types COPY at the terminal, the COPY command responds by 
printinq a series of questions to which the user replies at the termi- 
nal. 



DISK CONFIGURATION 

When asked, the user must specify the disk to be copied from (FROM) , 
and the disk to be copied to (TO) . The user is also asked whether or 
not the FROM and TO disks are 1.5M word disks. The size of the FROM 
disk and the TO disk must be equal; the user must be sure to specify 
disks of the same size when replying to the FROM and TO queries. The 
parameters specified are terminated by the CARRIAGE RETURN character. 
The FROM and TO parameters are physical device numbers; disk device 
numbers are listed in Section 1. Possible disk numbers are summarized 
as follows: 
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Physical Disk No. Associated Devices 

0-7 Type 4000 controller moving head disks; 

8 sectors/track 

10 Type 4000 controller fixed head disks; 

8 sectors/track 

20-27 Type 4300 controller diskettes; 

4 sectors/ track 

30—37 Type 4002 controller moving head disks; 

8 sectors/track 

40 Type 4002 controller fixed head disks; 

64 sectors/track 

50-57 Type 4002 controller moving head disks; 

32 sectors/track 

5050-5056 Type 4001 controller moving head disks; 

32 sectors/track 



(even numbers only) controller device 
address=21 

5250-5256 Type 4001 controller moving head disks; 

32 sectors/ track 



(even numbers only) ccr^roJ ler device 
address=23 

NOTE: 

The above information is also required to MAKE and 
FIXRAT. 
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COPY 



Controllers are normally delivered with address=23. 






If FHJM or iu is not a valid physical disk nunber, or 
replies NO to the query PARAMETERS OK?, COPY repeats the series of 
questions and waits for reply from the user. If the new parameters are 
acceptable, COPY initiates the copy operation. 



If the 30-million word disk is partitioned, 
individual partition of the disk. 



the user may COPY an 



Table 


6-1. 


Partitioned ] 


Disk Address i 






Device 


Device 






Address 23 


Address 21 


Partition 


alt) 


Disk No. 
XX025X 


Disk No. 


2 head (defai 


XX005X 


2 head (expl: 


Lcit) 


XX065X 


XX045X 


4 head 




XXI 2 5X 


XX105X 


6 head 




XX165X 


XX145X 


8 head 




XX225X 


XX205X 


10 head 




XX265X 


XX245X 


12 head 




XX325X 


XX305X 


14 head 




XX365X 


XX345X 


16 head 




XX425X 


XX405X 


18 head 




XX465X 


XX445X 


20 head 




XX525X 


XX505X 



In Table 6-1, the X's represent octal digits that must be set 
appropriately. The leftmost X's indicate head offset; and the 
rightmost X indicates one of the four possible drives connected to the 
controller. Refer to Section 1 for a complete explanation of the 
partitioned disks. 

Example : 

100252 

means a 3M word size partition with a head offset of 10 on the disk 
that is connected to the second drive (drive 2) connected to the 
controller . 

NOTE: 

COPY does not allow rewriting of the same disk. For example, 
specification of the same physical disk nunber in reply to the 
FROM and TO queries is an illegal specification of COPY 
parameters. 
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WARNING 



A TO disk number must not be a disk connected tc PRIMOS by the STARTUP 
command. It is good practice, when running COPY under PRIMCS II, to 
place all active disks in WRITE PROTECT before initiating the COPY com- 
mand, except for the disk to be written to (TO disk) . It is good prac- 
tice when running under PRIMOS III or IV, to place all disks assigned 
to the user terminal at which the COPY commana is to be initiated to 
WRITE PROTECT, except the TO disk, before ir?" Hating the COPY. 



COPY METHOD 

COPY copies disk records from the FROM disk to the TO disk and, when 
done, verifies the copy by reading each record from both disks and 
performing a word-by-word comparison in memory. Bit 1 may be ON as the 
high-order address bit of the storage module record number, during the 
copy phase. During this process, COPY displays the disk record number 
it is processing in the DATA lights on the processor control panel, 
bits 2-16. Bit 1 is off during the copy operation and on during the 
verify operation. When done, COPY prints DONE and returns to PRIMOS , 
which prints OK. If any disk read errors occur during the copy, the 
reed is retried nine times. Each error results in an error message of 
the form: 

DISK RD ERROR device-number PRlMOS-Record-number Status 



If the read operation is not successful after ten tries, PRIMOS ignores 
that record and prints the message: 

ERROR READING DISK Device-number RECORD Record-number 

ERROR IGNORED, COPY CONTINUED 

Then, PRIMOS continues the copy operation. If any disk write errors 
occur, COPY retries nine times. Each error results in an error message 
of the form: 

DISK WT ERROR Device-number PRIMOS-Record-number Status 

If the write operation is not successful after ten tries, COPY aborts, 
prints the error message UNRECOVERED ERROR, and returns to PRIMOS. If 
on either read or write a DISK-NOT-READY status is detected, a single 
disk error message is printed with the status 177776. The software 
then retries the read or write, waiting for the disk to become ready. 
If while verifying the copy, a discrepancy is detected, COPY prints 
VERIFY ERROR, the record number of the track that contained the error, 
and the word number within the track that did not compare correctly; 
verification then continues. 
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COPY Success or Abort 

If the COPY is successful, the message 

DONE 

is printed at the terminal (only if both the copy and verify were 
successful) . 

Disk with Badspots 

COPY can copy FROM a disk that has badspots. COPY looks for file 
BADSPT in the MFD (refer to the MAKE command description for details) . 
If the COPY command finds the file BADSPT in the MFD, COPY interprets 
the BADSPT file and skips reading bad tracks on the disk to be copied 
FROM. The corresponding tracks on the disk to be copied TO are written 
with data, in order to write good checksums. 

COPY skips writing tracks containing badspots on the TO disk. Those 
users who desire to use a disk containing badspots as the TO disk dur- 
ing a COPY operation should perform the following: create the FROM 
disk with the MAKE command and specify to MAKE the badspots on both the 
FROM and the TO disks. If the FROM disit already has something useful 
on it, the information must be backed up before invoking the MAKE com- 
mand. Then, the information must be retrieved fcJ lowing the MAKE of 
the FROM disk, using either the FUTIL or the MAGRST command. 

COPY CHECKSUM 



When copying a disk pack written using a 4002 controller or a 4000 
controller (or vice versa) , the two controllers generate different 
checksums. The command: 

COPY NOCHECKSUM 

copies the disk without checking checksums, thereby permitting the disk 
to be copied. During this procedure, there is a small risk that bad 
information will be copied without detection. 

NOTE: 

A FIXRAT of a disk copied from a disk with bad spots may cause the 
error message: 

DSKRAT, FILE DIRECTORIES MISMATCH 

This message is a result of the truncation of the BADSPT file, and does 
not indicate that the COPY was inaccurate. 

If the BADSPT file exists on the FROM disk, but has a bad format, the 

message: 



MM 21,03 6 " 5 *n-ryl977 
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BAD BADSPT FILE, IGNORED 

is printed; and COPY attempts to copy the disk as if the file BADSPT 
did not exist. Badspots are likely to occur on 30M-word disk packs. 
On these packs, a list of pairs of numbers is maintained inside the 
bottom cover. These pairs (track number, head number) represent 
probable badspots. It is worthwhile to try to copy a pack with 
badspots, for the purpose of backup. COPY skips writing tracks 
containing badspots on disks it copies TO. 

Copying Storage Module 

The COPY command handles the storage module disk (40-80M word disk) us- 
ing disk numbers as described in Section 1. In this case, the disk 
number is related to the number of heads in the disk partition as 
follows : 

Partition Disk Number 

1 head XX006X+1 

2 heads XX046X 

3 heads XX046X+1 

4 heads XX106X 

The storage module must be formatted by MAKE before it can be used. 
Therefore, a disk to be copied must be created by the MAKE command with 
the VIRGIN DISK question answered YES before it can be copied to. For 
further information, refer to MAKE in Section 5. The storage module 
disk need only to be created once (using MAKE) after it is recovered. 

Badspots on a storage module are handled the same way as on a 30-mil- 
lion word disk. 

EXAMPLE OF USE OF COPY COMMAND 

The following is an example of COPY use under PRIMOS II. Operation 
under PRIMOS III and IV is similar. 

OK: COPY 
GO 

FROM PHYS DISK= 50 

1.5M WORD PACK? YES 

TO PHYS DISK= 51 

1.5M WORD PACK? YES 

FROM, TO, RECORDS = 000050, 000031, 3248 

PARAMETERS OK? YES 
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SECTION 7 



This section describes commands that are normally used by the operator 

at the PRIMOS III or IV supervisor terminal. Some of these commands 

may also be available for use under PRIMOS II; if so, this is 
indicated in the command description. 

PRIMOS III IV INTERNAL COMMANDS 

When started, PRIMOS III and IV wait for a command at the supervisor 
terminal. A typical sequence of commands is: 

CONFIG 

SETIME 

STARTUP 

These commands and their arguments are described in the following para- 
graphs. All system commands are issued at the supervisor terminal. 

After PRIMOS III or IV is started, the PRIMOS II supervisor terminal 
becomes the PRIMOS III or IV supervisor terminal. Unless the USRASR or 
OPRPRI command is given, the supervisor terminal can be used only for a 
restricted set of operator commands, given in this section. Since the 
supervisor terminal operates in the supervisor address space, any ex- 
ternal commands and/or the RESTOR, RESUME, and START commands will 
crash PRIMOS III and IV if they are given at the supervisor terminal. 
Normally, the supervisor terminal is used only to STARTUP and SHUTDN 
disks, configure devices, check status, and to 
LOGIN, LOGOUT, and other messages. 
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********** 

* ADDISK * 
********** 

The command format is: 

ADDISK Pdiskl [Pdisk] ... [Pdisk] 

ADDISK searches the table of logical disks for an available table entry 
location; if one is found, ADDISK starts up the disk specified by 
Pdisk. ADDISK repeats this procedure for each argument specified. If 
a disk specified by Pdisk is already started, no action is taken. If 
there are no free logical disks, the error message: 

NO ROOM 

is printed at the supervisor terminal. 

ADDISK is available only as a PRIMOS III or IV command to be issued at 
the supervisor terminal. Since PRIMOS III and IV support 18 logical 
disks, ADDISK must be used to start up disks beyond logical 8. 
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********** 

* AMLC * 
********** 

The command format is: 

AMLC (.Protocol] Line [Config] [Lword] 

The arguments to the AMLC command have the following significancee. 

Protocol 

After the system is running, users may assign the AMLC lines through 
the following commands: 

ASSIGN AMLC [Protocol] Line [Config] 

UNASSIGN AMLC Line 

Line number (0 to 17 octal for PRIMOS II, to 37 octal for the 31-user 
PRIMOS III and IV) is assigned to the user, and I/O protocol and the 
line configuration word is established for Line. The following proto- 
cols are available: 

TTY - terminal protocol 

TTYHS - high-speed terminal protocol 

TRAN - transparent protocol 

TRANHS - high-speed transparent protocol 

TTYNOP - disconnects terminal 

Terminal protocol is used by lines controling interactive terminals. 
With terminal protocol, all input from the terminal is echoed if the 
line is set for full duplex and, in audition, a carriage return is 
echoed following carriage return. Bit 8 of each character is forced 
on* Note that .CTRL. P or BREAK does not cause th Q AMLC input/output 
program to QUIT. These characters are significant only at a PRIMOS III 
or IV user terminal. Both characters are ignored. A carriage return 
input by the terminal is transmitted as a new line to the program re- 
questing input. Input is no longer echoed if the line input buffer 
becomes full. Terminal protocol is identical to that protocol used to 
control PRIMOS III and IV user terminals, except for the action of 
.CTRL. P and BREAK. 

Transparent protocol is used by lines connected to peripheral devices 
or other computers. With transparent protocol, no input is echoed, no 
response is made to the input of a line feed or carriage return, and 
there is no transformation of carriage return to line feed. 

The high-speed protocols are used by lines connected to peripheral de- 
vices that can run at greater than standard terminal speeds. These 
protocols are the same as those describedabove with one exceptiong: 
for output only, the line's character time interrupt flag is set when 
the output buffer contains more than 40 characters, and it remains set 
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until the output buffer contains less than 40 characters. The proto- 
cols have a burst mode effect on the output device. 

With a line using the high-speed protocols, a drastic increase in sys- 
tem overhead can result - depending upon the baud rate and the number 
of lines in the group. The user must be careful not to assign proto- 
cols to lines that normally have their character-time-interrupt flag 
always set; as, for example, the last line in each group of lines. If 
the protocol is not given, the transparent protocol is assigned by the 
operating system. The line number is specified in octal and must be 
equal to or less than the parameter Nuser. See Figure 7-1 for details 
about the line configuration word. 

Line 

Line, the AMLC line number, is an octal number from 1 to 17. 

Config 

The Config argument which sets the line configuration, is an octal num- 
ber that corresponds to the bit pattern illustrated in Figure 7-1. For 
exAmple, the number 2213 would specify a data set at 300 baud with par- 
ity disabled and eiqht-bit character length (see Figure 7-1) . 

Lword 

The optional parameter Lword is an octal parameter divided into a num- 
ber of significant parts. If Bit 1 of Lword is set, the line is half 
duplex; if Bit 1 of Lword is reset, the line is full duplex. Bit 2 
set indicates that LINE FEED is not to be echoed for CARRIAGE RETURN. 
Bit 2 reset indicates that LINE FEED is to be echoed for CARRIAGE 
RETURN. Bits 8 through 15 of Lword contain the number of the user to 
which the AMLC is connected. This user number is the number printed at 
the terminal upon LOGIN or LOGOUT, or printed by the STATUS command in- 
dicating user number. Although STATUS prints the User Number in deci- 
mal, the user must specify the User Number in octal when specifying 
this value in the AMLC command. If the rightmost eight bits of Lword 
are zero, the AMLC line is not associated with any user space and is 
available to be assigned. 

The AMLC command may be used to configure ASSIGNed AMLC lines as well 
as terminal AMLC lines. 
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1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 

Bits Assignment 

1-4 Line number (bit 4 is LSB) 

5 Not used 

6 Data Set Control Bit (l=on) 

7 l=Loop line,0=do not loop 

8-10 Octal Value Line Speed (Data Rate) 

110 Baud 

1 134.5 Baud 

2 300 Baud 

3 1200 Baud 

4 Not Assigned* 

5 75 Baud* 

6 150 Baud* 

7 1800 Baud* 

Note 

Speeds marked with * are assignable by hardware jumpers. The 
speeds shown are the default values. Other choices are 75, 
150, 600, 1800, 2400, 4800, 9600 or 19200 Baud. 

11 Not used 

12 0= 1 stop bit, 1=2 stop bits 

13 0=enable parity, l=disable parity 

14 0=odd parity, l=even parity 

15-16 Character length: 

5 bits 
10 6 bits 
17 bits 
118 bits 

Figure 7-1. Setup of Line Configuration 
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CONFIG Nuser Pagedevl Coindev [Availm] [Pagedev2] [Namlc] [NPhan] 

Nuser An integer less than or equal to octal 40 that 

defines the number of users, including the super- 
visor (e.g., for a four-user system, enter 5; 
for a seven-user system, enter 10} . 

Pagedevl A physical disk number that specifies the 
device to be used for paging. See Table 3-1 
for possible values. 

Comdev A parameter that specifies the physical device number 
initially assigned as logical 0. Vfrien a user 
invokes an external command, the command directory 
CMDNC0 is searched on this device. If Comdev and 
Pagedev are the same, the disk is considered to be 
split into a file system and a paging part. The 
boundary between the partitions is defined by the 
DSKPAT header, and it may be set by the MAKE program. 
(See the paragraph on configuration at the 
beginning of this section.) 

Availm An optional argument that defines available 
physical storage. It corresponds to the last 
sector number (octal) to be used. The values 
for Availm and associated storage used are 
as follows: 



Blank or All of Memory 



(must be at least 32K) 



117 


40K 


137 


48K 


157 


56K 


177 


64K 



'777 



256K 



Pagedev2 CONFIG may specify either one or two disk 

devices on which paging is to take place. CONFIG 
does not allow the alternate paging device to 
be a split disk. 

Namlc An optional argument that defines the number 
of assignable AMLC lines. 

NPhan An optional argument that defines the 
number of phantoms. 

The CONFIG command uses the range of acceptable Pagedev and Comdev 
codes (Physical Disk Numbers) , as shown in Table 2-1. 
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Example : 

A Cl ITViKW 1 CT^T* form inal r\r*iaY-^+-r\r imaTr T.7-1 e?1n i-r\ rrw/^ -J -Pr» 4-t.vn »-N-^^f -I 1-1^ *3« 

vices to run a 30-user system using 3.0-million word disk packs. 
If each user's virtual space is set to be 64K, only 23 users will 
fit on a 3.0-million word disk pack. Thus the use of two paging 
devices is required. The command line: 

CONFIG 30 31 30 

allows paging device to be physical devices 30 and 31 for a 30-user 
system. 

Command File with CONFIG 

It is possible to start up PRIMOS III and IV with a command file that 
contains the CONFIG command. To do so, the user generates a command 
file named C DOSV and places this file in the UFD CMDNC0. The first 
line in the command file C_DOSV must be a CONFIG ccmmand. The command 
file C DOSV may contain other PRIMOS III or IV internal commsnds such 
as STARTUP and MESSAGE, but the command file must terminate with the 
command line: 

CO TTY 

If CMDNC0 has a password, the nonowner password must be null and C_DOSV 
must have read protection rights for the nonowner. 

Starting PRIMOS III or IV from a Command File 

To bring up PRIMOS III or IV from the command file C DOSV, the operator 
first starts up, under PRIMOS II, the physical disk that is to be logi- 
cal disk at the supervisor terminal. This logical disk will be the 
command disk under PRIMOS III or IV. The operator then enters the com- 
mand : 

PRIMOS 

The PRIMOS III or IV operating system then starts running and checks if 
a command file C DOSV exists in the UFD named CMDNC0 or logical disk 0. 
If C_DOSV does not exist, PRIMOS III or IV will take commands from the 
system terminal. If C DOSV does exist, it will read commands from the 
ccmmand file until it encounters the command line, CO TTY. Subse- 
quently it will return to PRIMOS III or IV and take commands from the 
terminal . 

Errors 

If the user types a detectable error while issuing the CONFIG command, 
the system requests that the CONFIG command be retried. 
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********** 

* DISKS * 
********** 



The command format is: 

DISKS [NOT] Pdisk0 [Pdiskl] ... [Fdisk8] 

The DISKS command may be given only from the supervisor terminal. The 
DISKS command adds or removes the specified physical disk(s) to/from 
the assignable Disks Table. R3isk0 ... D3isk8 are physical disk num- 
bers. No more than ten disks may be entered into the Assignable Disks 
Table. A physical disk number must be specified in this table before a 
user can invoke the ASSIGN command to assign that disk. 

When the optional argument NOT is specified in the DISKS command line, 
the subsequently specified physical disks are removed from the Assign- 
able Disks Table. Removing a physical disk number from the table does 
not cause the disk to be unassigned; the operator must give the 
UNASSIGN command to unassign a disk from a user. 

Example : 

OK, DISK 1 20250 50250 60250 70250 10020 110250 20252 

adds the specified physical disks (disk 1) and partitions (20250, etc.) 
to the Assignable Disks Table. These disk and partitions may now be 
ASSIGNed by the users or operators. The command sequence: 

OK, DISK NOT 20250 OK, UNASSIGN 20250 

removes the physical disk partition 020250 from the Assignable Disks 
Table and unassigns that partition. 
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*********** 
* MESSAGE * 

The PRIMOS III and IV internal command MESSAGE 1) provides a message 
facility that at the supervisor terminal; 2) allows an operator, at 
the supervisor terminal, to communicate with all users at all terminals 
connected to the system; or 3) allows an operator to communicate with 
a specific user at a specific terminal. The format for user to opera- 
tor message is: 

MESSAGE 

text of message 

where (text of message) is a one-time message. Two lines are printed 
at the supervisor terminal. Their format is: 

*** uu hh'mm 
text of message 

where: uu is the user number; hh'mm is the time of day in hours and 
minutes. 

The format of an operator to user message is: 

MESSAGE ALL 
MESSAGE ALL NOW 
MESSAGE -uu 
MESSAGE -uu NOW 

The operator can send messages to all users or to a single user. When 
the parameter ALL is specified, the message is sent to all users. The 
parameter -uu is a minus followed by the user number. When the para- 
meter -uu is specified, a message is sent to the user specified. 

If the optional argument NOW is not specified, the message is stored in 
a Broadcast Buffer (ALL) or a Single User Buffer (-uu) . The message is 
printed at the user's terminal when that user returns to PRIMOS III or 
IV command level. A message that is in the Broadcast Buffer is also 
printed after a user issues the LOGIN command. 

If the argument NOW is specified, the message is printed immediately. 
This is an unfriendly thing to do if the user is in the midst of a 
sensitive operation. When NOW is specified, stored messages are not 
affected. Also, when NOW is specified, the format of the message at 
the user terminal is: 

*** BULLETIN *** 

If the operator attempts to send a message to a single user before the 
previous message to a single user has been receive, the error line: 
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MESSAGE NOT SENT 

is printed at the supervisor terminal. 

To cancel a stored message, a null line must be entered as the text of 
message. 
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********** 

* SETIME * 
********** 

The SETIME command sets date and time. It can be entered at any time 
during system operation. The format is: 

SETIME -mmddy -hhmm 

where mmddy are digits that represent the month, day, and year (last 

digit only) , and hhmm are digits that represent the time in hours and 

minutes. The two arguments to SETIME must be separated by spaces and 
start with a minus sign as the first character. 

Example : 

SETIME -09296 -1630 

sets the date and time: September 19, 1974, 4:30 PM. 
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*********** 

* STARTUP * 
*********** 



The STARTUP command defines a list of physical disk devices to be used 
by PRIMOS II, III or IV. A disk is considered started if it has been 
mentioned in a previous STARTUP command. Additional disks may be 
started if the new list in a subsequent STARTUP command does not con- 
flict with the list in a previous STARTUP, and if no user has assigned 
a disk specified in the list. The format is: 

STARTUP Comdev [Pdevl Pdev2 ... Pdevn] 

where Comdev and Pdevl . . . Pdevn are items in a list of physical disk 
(device) numbers. The argument, Comdev, must be specified in the 
initial STARTUP command; the remaining device numbers are specified 
optionally. The order of the list defines the logical number sequence 
of the devices (e.g., Comdev is logical 0, Pdev 1 is logical 1, etc.) 
Physical device codes are listed in Section 1. 

Comdev must match the Comdev specified in the CONFIG command. 

Example : 

STARTUP 52 53 54 

defines that physical devices 52, 53, and 54 are to be used with PRIMOS 
III and IV and associates the following logidevice numbers with the 
physical device numbers specified: 52 is logical 0; 53 is logical 1; 
and 54 is logical 2. In PRIMOS III and IV logical device numbers may 
also be specified as arguments to the STARTUP command. When used in 
this manner, they must be followed by a slash and the associated physi- 
cal device number. Examples: 

Examples: 

STARTUP 0/52 1/53 2/54 

STARTUP 4/100250 
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********** 

* SHOTDN * 
********** 

The SHOTDN command performs tasks necessary to shutting down the PRIMOS 
III or IV system in an orderly manner. The format is: 

SHOTDN 

SHTDN Pdev [Pdev2 ... Pdevn] 

SHOTDN ALL 



The command form: SHOTDN ALL performs a complete PRIMOS II or IV sys- 
tem shutdown. All user files are closed, physical disks are closed, 
and the PRIMOS III and IV systems shut down by inhibiting interrupts, 
exiting page mode, stopping the system clock, and halting. SHOTDN with 
no arguments specified performs the same functions f=r PRIMOS II. 

If the SHOTDN command is issued with a list of physical devices (Pdev0 
Pdevn) , the listed devices are closed by closing all files opened 
in the listed devices and by detaching all users attached to the listed 
devices. Refer to Section 1 for a complete discussion of physical de- 
vice numbers) . Then, the specified disks are not available for PRIMOS 
file I/O operations until the devices are specified on a subsequent 
STARTUP command. The STATUS command can be used to list the devices 
currently started up. Unlike the STARTUP command, the Pdev 's do not 
have to be given in logical drive order. 

CAUTION: 

Do not shut down the physical device associated with logical 0, or 
PRIMOS III and IV will lose the command directory (from memory, 
not disk) . To recover, STARTUP the disk and ATTACH CMDNC0. 

Example of Selective Shutdown 

Assume the initial STARTUP command was: 

STARTUP 51 50 56 54 

The operator wishes to replace the pack on physical device 56, which is 
logical device 2. The operator gives the command SHOTDN 56, stops the 
drive, replaces the pack, and restarts the drive. The operator then 
gives the command: 

STARTUP 2/56 

to startup physical drive 56 as logical device 2. 
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********** 

* STATUS * 
********** 



The STATUS command may be used to monitor the usage of PRIMOS III and 
IV. When entered at the supervisor terminal, it prints user terminal 
status information and a list of current logged- in users. The user 
terminal number and the numbers of the physical disks currently being 
used are printed after each user name. User-assigned devices are list- 
ed after the number of the physical disk that is currently being used. 
A disk is considered to be in use by a user (1) if his home UFD or cur- 
rent UFD resides on the disk or (2) if the user has opened a file on 
that disk. Some typical instances where the STATUS command must be 
used are: 

1. Prior to mounting a new disk pack to determine 
what physical disk assignments are available. 

2. After a request that all users release s given disk 
or disks, to determine that they have done so before 
shutting down that disk or disks. 

3. As a check that all users have logged out before 
shutting down PRIMOS III and IV. (No harm to the system 
results if the users of a particular disk are still 
logged-in when the disk or the system is shut down. However, 
the user's files are closed and a message is printed at the 
terminal to that effect.) 

Examples : 

STATUS Command at the Supervisor Terminal 

OK, STATUS 

USR = SYSTEM 

FUNITS 



DISK LDEV PDEV 



TS 





250 


SPOOLD 


1 


250 


DUD 


2 


20250 


DSKRAT 


3 


50 


ADMIN 4 




110250 


ETCH 


5 


40250 


PMFII 


6 


100250 


MD6V2 


7 


4 



TRANS 10 50250 
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PAGEDEV = 10252 COMDEV = 250 



USER 


LINE 


PDEVS 


JOEL 


2 


110250 


SPOOL 


3 


252 PR1 


COHEN 


4 


50 PTR PUNCH 


MERRIC 


5 


250 


QOUDY 


8 


20250 


PODUSK 


13 


250 


JDOAKS 


16 


110250 



OK, 



STATUS Conmand Issued at a User Terminal 



OK, STAT 






FUNITS 






DISK 


LDEV 


PDEV 


TS 





252 


SPOOLD 


1 


250 


DUD 


2 


20250 


ETCH 


3 


40252 


LSTFIL 


4 


50250 


DOSDVM 


5 


60252 


WORKII 


7 


100252 


ADMIN 


10 


110252 



- 15 
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********** 

* USRASR * 
********** 



The USRASR command allows the supervisor terminal to act as a user ter- 
minal by associating it with a different address space. After initiat- 
ing USRASR, it is still possible to invoke supervisor commands by means 
of the proper form of the USRASR command. The format is: 

USRASR Usrno 
where Usrno is a user number. 
Example : 

USRASR 4 

Restrictions 

The USRASR command works only if the associated communications 
line is not enabled on the AMLC. If connected to a current loop 
bit- banger line, the input leads must be shorted (or a terminal 
must be connected to the line) . 

Return 

To return to operations as a normal supervisor terminal, type: 

USRASR 1 
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SECTION 8 
COMPUTER ROOM OPERATIONS 



OPERATIONS EXAMPLE 

This section describes computer room operation for a typical 
installation. It is intended as a guideline for progranming personnel 
who may have to startup or troubleshoot the system unaided late at 
night or on weekends. While some of the details may differ from 
operation of the user 's computer configuration, the principles are 
similar and the techniques are useful as a general guideline for 
computer room operation. 



DEFINITION OF TERMS 
Term 
Set Sense Switch 

SSW=XXXXXX 



Bits 

Press Sense Switch 

Press Sense SSW=XXXXXX 

DATA CLEAR 
MASTER CLEAR 



Definition 

On the computer 's control panel , a sense 
switch is set if it is in the UP 
position. 

Where XXXXXX is an octal number, set sense 
switches to equal the number XXXXXX. Example: 
to set SSW equal to the number, 14, set bits 
of sense switches 13 and 14. 

A bit corresponds to a sense switch 8-16 
on the control panel. 

On the computer's control panel, press 
the sense switch downward. 

Where XXXXXX is an oct?3 number, press 
sense switches to equal the octal number 
XXXXXX. 

Press DATA CLEAR switch on control panel. 
Press MASTER CLEAR switch on control panel . 
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STARTING UP PRIMQS 

To start up PRIMOS, proceed as follows: 

BOOT in PRIMOS II (see Section 1) 

Startup disk with the UPD that contains PRIMOS. 

The following is an example of how PRIMOS is currently being 
started up. 

Example : 

PRIMOS NOT IN OPERATION 



PHYSICAL DEV = 50 

PRIMOS REV. XX. XX MM/DD/YY (AT 170000) 



OK: START UP 50 
OK: A SYSTEM 
OK: R PRIMOS 
GO 



CONFIG SYSA 30 20061 50 5/2 5 
PRIMOS 4 <REV 11.31> 
506.0 K MEMORY IN USE 

PLEASE ENTER DATE 

OK, ADDISK 
OK, A SPOOL 
OK, PH C<-SPOOL 
OK, A FAM 
OK, CO C<-FAM 
OK, A SYSTEM 
OK, PH C<-CX 



PRIMOS has been started up. After typing 'R PRIMOS', only 
the date and time need be typed. The command file enters 
the CONFIG and starts up all normally started disks. 
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BOOTING IN (PRIMOS II) 

The technique of Booting in PRIMOS II is as follows: 

Set sense switches according to Table 8-1 in order 
to BOOT in PRIMOS II from the device listed. 

Set rotary switch to STOP STEP. 

MASTER CLEAR. 

Set rotary switch to LOAD. 

Press START switch. 

Table 8-1. Sense Switch Settings to Specify Bootload Device 

DEVICE SSW= 



TS TIMESHARE DISK 14 

FLOPPY DRIVE 6 

PAPER TAPEHIGH SPEED 2 

PAPER TAPEASR 1 

STORAGE MODULE 10014 



The Systems Terminal prints: PHYSICAL DEV =. The operator 
then types the device number of the device containing 
a version of PRIMOS II. 

In most cases, PRIMOS II is booted in from the Time-Share (TS/A) 
disk (SSW=14 and PHYSICAL DEV = 50) 



CRASH PROCEDURE 

NOTE 

It is important that all actions and analysis 
be recorded, preferably in the log book entitled 
'log book - System A') 

Illegal Commands Typed at the Systems Terminal 

If a crash is caused by typing an illegal command at the systems 
terminal, all disks have to be checked using FIXRAT (refer to Section 4 
and the File System User Guide (MAN 2604) for details) before PRIMOS 
can be restarted. Certain command files may be used to run FIXRAT for 
the purpose of fixing disks. 
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NOTE 



If the systems terminal is left at the default OPPI 0, the system 
does not allow this type of crash to occur. 

Hung System 

If a disk is added to the system with the ADDISK command and is not in 
the ready state (ready light on disk drive indicates ready state) , the 
system hangs for about 30 seconds. To check other possible causes of a 
hung system: (1) make sure line printer is on, (2) check select lock 
on 30-million word disk drives. If locked, clear and report lock to 
maintenance department. 

Crash 

Upon a systems crash, the rotary switch on the control panel is set to 
STOP STEP, data/address (DA/AD) switch is set to ADDRESS. Do not 
MASTER CLEAR unless specifically instructed to do so. If the number 
displayed in the data light '26303, the crash is a memory parity 
halt. If any other number is displayed, see a programmer if possible 
If not, follow the procedure below to take down registers, then BOOT in 
PRIMOS II FIXRAT all disks, and restart PRIMOS III. If data lights 
show a '26303 (memory parity halt) , follow the procedure below; if 
available run the memory parity finder, if possible. The memory parity 
finder locates bad pages in memory and allows the user to make them 
unavailable for use. This procedure often allows the system to be 
warm-started. Under PRIMOS III or IV, the user with the bad page of 
memory at the time of the crash must log out immediately after PRIMOS 
is restarted. This logout can be done from the user terminal or from 
the systems terminal by the command 'LO -(-UU) ', where UU is the number 
of user with the bad page of memory at the time of the crash. 

The following paragraphs give a checklist of precedures to follow in 
the event of a system crash. 

Registers 0- '37 ere taken down (recorded in log). 



The procedure is: 

Set rotarY switch to fetch Y. 

Set DA/AD switch to ADDRESS. 

DATA CLEAR. 

Press START switch; address is displayed. By setting DA/AD 
switch to DATA data at ADDRESS or register is displayed on 
panel lights. Take down data at address . 
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Set rotary switch to fetch Y+l. Press START switch. DA/AD switch 
set to DATA shows data at address 1 . DA/AD switch set to address 
shows a i for address i . 

Every time START switch is pressed, the next data/address 
correspondence can be accessed and taken down. Continue this 
process for registers 8- '37. 

Data at addresses '25463 (SUPSW) and '25477 (CUSR) , are also recorded 
into the log. 

The procedure is: 

Set rotary switch to fetch Y. 

Set DA/AD switch to ADDRESS. 

DATA CLEAR. 

Press SSW= '25463 . (Press bits 3,5,7,8,11,12,13 ) 

Press START switch. 

Set DA/AD switch to DATA. 

Record data in log, and repeat above procedure for CUSR. (Press 
SSW= '25477 instead of '25463) 

Run memory parity finder (if available) by warm starting PRIMOS. If 
any bad pages are found, the bad page numbers are typed with the 
following message: 

PARITY ERROR AT ABOVE PAGES 

STOP, FIX MMAP AND PAGEMAP, WARM START 

Locking Out Bad Pages 

(For example, assume that page 247 is found to be bad: 
The procedure is: 

Add 22000 to the bad page number (e.g. ,22000+247=22247) . 

Set rotary switch to fetch Y DATA CLEAR. 

Press SSW=bad (the calculated number of the bad page; 
in this case '22247) page number+22000. 
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Set DA/AD switch to DATA. 

NOTE 

1. The nunber displayed by setting the DA/AD switch 
corresponds to a memory location. 

2. If the number displayed is less than 2400, the 
system cannot be warm-started. 

3. The user number found by the MMAP 

is a user who must logout immediately after 
the system is warm-started. 

Set rotary switch to store Y. 
Press SSW=177777. 
Press START switch. 
Continue this process for any other bad pages found. 

WARM-STARTING PRIMOS 
The procedure is: 

Set rotary switch to RUN. 

Press START switch twice. 

If applicable, LOGOUT users with bad iremory pages 
at the time of crash. 
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Example log containing data taken after a systems memory parity halt: 

r>_ _U~~ "I fil TQ-7C 

Registers-Contents Bad Page No. Displacement Contents 

15 247 622 120261 

1 247 727 40763 

2 63670 251 127 12401 

3 177777 

4 37254 

5 177777 

6 142400 

7 26272 

10 4 

11 4 

12 1400 

13 217 

14 14 

15 14 

16 4015 

17 5511 CUSR=5 

20 176402 SUPSW=1 

21 22317 

22 

23 

24 

25 

26 

27 

30 

31 

32 

33 

34 1 

35 16000 

36 

37 133534 
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POWERING UP OR DOWN SYSTEM 

Powering Down 

To power down, key top left rotary switch to OFF, after shutting down 
all disks with the command 'SH ALL'. Shut down all other devices if 
the main power is to be shut down. Shut off the 30-mill ion-word disk 
drives with their STOP-START switches. Then shut off the main circuit 
breakers on the drives. These circuit breakers may be accessed by 
opening the front panels on the drives. 

Powering Up 

To power up, turn on all devices that were turned off. Power up the 
30-million word drives by turning on the main circuit breakers. Then 
turn on START-STOP switches. 

COMMAND FILES FOR FIXRAT AND COPY 

The following command files are site-specific to one computer site, but 
they are described to show that FIXRAT and COPY may be run from command 
files. 

FIXYES 

FIXYES is a command file in UFD=System Name. FIXYES runs the FIXRAT 
option on all disks normally started up. It does not FIXRAT the 
1.5-million word drive(s) . If the 1.5-million word disk is to be 
FIXRATed, it must be done by hand to run FIXYES, BOOT in, 'STARTUP 50', 
'A System', and 'CO FIXYES'. 

FIXNO 

FIXNO runs the same as FIXYES but does not fix the disk. FIXNO does 
not FIXRAT the 1.5-million word disk drives. 

C<-COPY 

The command file CjCOPY writes out a map to the terminal (CjCOPY is run 
from the supervisor terminal) showing where the backup disk is to be 
placed for each copy. (At present, copying 30-million word drives 
requires three COPYs) . CjCOPY checks packnames in between copies, the 
command file pauses so that disk packs may be changed. The backup disk 
is indicated by BK following the backup drive number in the map that 
CjCOPY prints. 

COPY by Hand 

COPY may be invoked by hand. To COPY all ten partitions of a 
30-million word disk drive, 'the FROM:, TO:,' queues responses are 50XX 
50YY 30 ,where XX is the FROM device number, YY is the TO device number 
(in both cases, XX and YY are 50, 52, 54, or 56). For further 
information about COPY, refer to Section 6. 
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STARTING UP DISKS 



Under PRIMOS III and IV, all disks are started up with the ADDISK 
command (described in the Interactive User Guide MAN 2602) . The 
1.5-million word disk drive is started up as device 36 for an 8 
sectored disk or 56 for a 32 sectored disk. Physical disk numbers are 
discussed in Section 1. Figure 8-1 shows the location of the disk pack 
number and disk pack label on the disk pack. 



| XXXX-SS | DISK I 

1 I I- 

| | LABEL I 



Figure 8-1 Disk Device Numbers. 

The number on the face of the disk pack, SS, indicates the number of 
sectors. Sectoring may also be determined by counting notches on the 
bottom of the disk pack. SS will be either an 8 or a 32. 

PRIMOS II 

Only disks started up at the last 'STARTUP' are currently started up. 

VDOS64 

Any disk that is not started up under PRIMOS II may be started up under 
PRIMOS III or IV. The user who starts up a disk under PRIMOS III or IV 
is the only user that may access the disk. Only commands under CMDNC0 
of that disk may be invoked, unless a program is restored before 
invoking PRLMOS III or IV. The following is an example procedure for 
executing a program under PRIMOS III or IV. In this example, the 
program is not under CMDNC0 of the disk started up in VDOS64, but under 
CMDNC0 of an ADDed disk. 

Command Given at Command Given at 
Step Systems Terminal User Terminal 

1 OK, DISK 56 

2 OK, AS DISK 56 

3 OK, REST PROGM 

4 OK, SVC 1 

5 OK, VDOS64 

PRIMOS REV 11.33 2/2 '5 (AT 170000) 
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6 




OK: STARTUP 56 


7 




OK: A UFDNAM 


8 




OK: S 1000 

(PROGRAM EXECUTES HERE) 


9 




OK: SH 


10 




(TYPE CONTROL P) 
QUIT, 


11 




C ALL 


12 




OK, SVC 


13 




OK, UN DISK 56 


14 OK, 


DISK NOT 36 





WRITING TO A WRITE-PROTECTED DISK 

If a request is made to write on a WRITE-PROTECTED disk, an error 
message indication is printed at the user terminal as well as the 
supervisor terminal. The first six-digit number typed as part of the 
error message is the WRITE-PROTECTED disk number. To shutdown the disk 
from the supervisor terminal, use the SHUTDN command as many times as 
necessary. 



USING MAGRST AND MAGSAV 
MAGSAV 



Responses to the following MAGSAV, MAGRST request are: 



TAPE UNIT: 



ENTER LOGICAL TAPE NUMBER: 



TAPE NAME: 
DATE: 
REV NO: 

NAME: 



The physical number as dialed on device 
(9-track V only; at Rev. 11, MAGSAV does 
not accept 7-track tape. 

The response is 1 for the first 
logical tape, 2 for the second, etc. 
MAGSAV will rewind and reposition. A 
response of implies that the tape 
is already positioned correctly 
and MAGSAV takes. no action. 

Any six-character name. 

MM DD YY 

An arbitrary number. 

The response is either a file name or a 
MFD that saves the MFD to which the disk 
is currently attached. Alternate responses 
are: $A, $R, $Q. $A changes the home UFD 
via an ATTACH. 
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Example : 

$A USERX PASSWD LDEV 

$Q and $R each terminate a logical tape and return 
to the operating system. $R also rewinds the tape. 
NAME: is printed when writing has been completed, so that 
further writing may be requested or the current 
logical tape may be terminated. 

MAGRST 

All restoring takes place in the home UFD. MAGRST asks for the tape 
unit and the logical tape number exactly as in MAGSAV. MAGRST then 
prints out the name, date, and Rev on the user terminal and asks: 

READY TO RESTORE: The responses are YES, NO, or PA (Partial) . 
YES restores the whole logical tape. NO requests a new 
tape unit and loqical tape combination. PARTIAL permits 
a RESTOR of part of a tape. 

TREE NAME: This is the response when a partial restore is 
requested. The response is in the form: 

NAME1 > NAME2 > . . . > NAMEx 

Any file on the logical tape whose tree name begins with the 
sequence entered is restored. 

Example : 

All tree names in a level 1 SAVE (MFD) begin with MFD, 
so the tree name to restore an entire UFD would be 

MFDXJFDX, 

For further information about MAGSAVand MAGRST, refer to the 
Interactive User Guide (MAN 2602) . 



MOUNTING A TAPE ON THE 9-TRACK TAPE TRANSPORT 

Mount the tape as shown on the diagram on the inside of the tape 
transport's front cover. Turn bottom reel by hand three revolutions to 
secure tape. Press LOAD button twice. Press ON LINE button. To 
rewind, press RESET button and then rewind button. If the WRT EN 
(WRITE ENABLE) light is lit, writing is allowed. If not lit, then the 
WRITE ENABLE ring is not mounted on the reel of tape, and writing to 
the tape is not allowed. 
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LINE PRINTER OPERATION TIPS 

For efficient line printer operation, observe the following: 

PAPER JAM: Press STOP button and re-insert paper. If 

part of a file is lost, the file may be reprinted from its 
start by logging out SPOOL (by typing LO -30 at the systems 
terminal) and restarting it after performing the following 
steps : 

1. Dump the output buffer of the printer. 

2. Press the RUN button to dump anything left in the buffer. 

3. Then restart the SPOOL program. For example, at a given 
computer site, the SPOOL program may be started from 

a command file by typing: 

CO START SPOOL 

ALIGNING PAPER: After paper has been clamped on the line printer, 
adjust the paper so that its fold mark is about one quarter 
of an inch above the hammers. Refer to the Line 
Printer User Guide (MAN 1942) . 

PRIMOS IN NETWORKS 

The 15-user version of PRIMOS III or IV, together with a symboint 
called FAM, provide a file-sharing capability to all users in a 
two-node network comprised of two Prime 300, two Prime 400, or one 
Prime 300 and one Prime 400 computer systems. The operation of the 
network is described in the Interactive User Guide MAN 2602; the 
commands used to startup and run the network software are also 
described in that user guide. The network supports file sharing, which 
is the ability to use standard file system calls and commands to 
manipulate files on a set of disks that may be physically connected to 
the remote as well as the local computer. All computers are connected 
by an Interprocessor Controller (IPC) that allows high-speed 
communication between the memories of two Prime computers. 
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BOOTSTRAPS 



INTRODUCTION 

When power is first turned on, the semiconductor read/write memory of a 
Prime CPU is empty. To start operation, the operating system must be 
loaded from disk. To start this process, a short bootstrap program 
contained in a Read-only memory (physically located on the control 
panel) takes control temporarily. It loads a more extensive bootstrap 
from disk into main memory. Control then passes to this longer 
bootstrap, which completes the job of loading the memory image of the 
operating system from disk. 

This appendix describes Prime bootstraps: control panel bootstraps 
(and key- in substitutes) ; and second level bootstraps stored on paper 
tape, magnetic tape, disk, or the storage module. 



CONTROL PANEL BOOTS 
Control Panel u — code 



A control panel can have either 256 or 512 16-bit words of PROM from 
which bootstrap programs can be loaded into memory. After pressing 
MASTER CLEAR and dialing the selection switch to the LOAD position, 
press the^ START switch to cause the control panel u-code to read PROM 
locations '0 to '50 into memory locations '6 to '56 and begin execution 
in 16S mode at the address loaded into Location 7. This initial 
program, the pre-boot, can then read succeeding PROM locations into 
memory with the following instruction sequence: 

LDA (PROM address) 

OTA '1720 (address setup - same as display data lights) 

INA '1420 (input PROM location) 

STA (memory location) 

For some applications, the initial '51 words may be sufficient to code 
a complete bootstrap. Caution must be exercised when coding a program 
to execute in the register file (locations '0 to '37) , because some 
instructions alter registers. 

Prime Pre-Boot 

The Prime pre-boot saves the A-register in location '57 and then 
selects among three classes of bootstraps and stores the appropriate 
code from the PROM into memory. The three classes of bootstraps are 
auto-start, paper tape, and mass storage boots. The user selects the 
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desired boot by setting Sense Switches 14, 15, and 16 as follows: 
SS = 14 15 16 Code 

Auto-start 

ASR paper tape (MDL format) 
High speed paper tape (MDL format) 
Fixed head disk 
Moving head disk 
Magnetic tape 
Floppy disk (diskette) 
1 1 1 =7 Spare 

Device Specific Boots 

Auto-Start (0) : enters 64R mode and jumps to the location specified in 
Sense Switches 1 to 10 ('100 to '177700). If no address is specified, 
a default of '1000 is used. 

Paper Tape (1 2) : Modifies itself for either ASR or high speed paper 
tape (by sense switches) and reads a second-level MDL boot into memory. 
This boot requires that the first nonzero frame on the tape be '20 and 
the next two frames be '004/010 = '2010 =JMP '10. If # the initial 
A-register setting (saved by the pre-boot in location '57) is to be 
used, it must be saved before location '57 is loaded by the bootstrap. 
The first zero frame on the tape causes the JMP '10 instruction in 
location '20 to be skipped. When execution starts at location '21, the 
following locations have been set up: 

Location Contents Instruction (X=l for PTR, =4 for ASR) 



'3000X 


OCP X 


'13100X 


INA *100X 


'1310 0X 


INA '100X 


'002010 


JMP *-l 


141240 


ICR 


'13000X 


INA X 


'002013 


JMP *-l 


'050000 


STA 0,1 


'140114 


IRX 


'100040 


SZE 


'002010 


JMP '10 (from tape) 



2 

3 
'10 
'11 
'12 
'13 
*14 
'15 
'16 
'17 
'20 

Mass Storage (3-7) : performs further selection for fixed-head disk 
(FHD) , moving head disk (MHD) , magnetic tape, diskette, erd spare, all 
of which are loaded by the pre-boot. 

FHD (3^ : Sense Switch 13 is used to select between controller 4001 (SS 
13 reset) and controller 4002 (SS 13 set) . Sense Switch 12 is used to 
select between device addresses *21 fSS 12 reset) and '23 (SS 12 set) . 
The boot reads record (448 word PRIMOS record format)^ of the disk 
starting at location '770 and begins execution at '1000 (via a JST 
'777) . This boot waits for the drive to come ready and retries on 
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status errors. 

CC = 10 1? 

x" 1~ 

1 

1 1 



MHD (4) : Moving head disks come in three varieties: two platter 
drives (3M or 6M words) on either 4000 or 4002 controllers, 20-surface 
drives on the 4001/4002 controller, and 80MB or 300MB storage modules. 



Sense Switches 


11, 


12, 


and 


13 are used as follows 'X - 


SS = 11 


12 


13 


14 




X 





X 





4000, upper surface 


X 


1 


X 





4000, lower surface 











1 


4002, lower surface ('21) 





1 





1 


4002, upper surface ('2]) 








1 


1 


4002, upper surface ('23) 





1 


1 


1 


4002, lower surface ('23) 


1 


X 





1 


Storage module ( '26) 


1 


X 


1 


1 


Storage module ( '27) 



In all cases, except the storage module, record (448 words PRIMOS 
record format) of the selected surface of physical drive is read into 
memory starting at location '770 and execution is begun at '1000 'via a 
JST '777) . In the storage module, a 1040-word PRIMOS II record is read 
into memory starting at location '760 (to allow for the 16-word header) 
and execution is begun at '1000, as for other disk bootstraps. The 
moving-head disk and storage module bootstraps wait for the disk drive 
to become ready, and the bootstraps retry on the occurrence of status 
errors. Selection of the lower surface on a 20-surface MHD translates 
to: 

Record on Head 2 



MT (5) : Sense Switch 12 is used to select between 9-track (SS 12 
reset) and 7-track (SS 12 set) magnetic tape drives. The boot starts 
up the drive, ensures that the tape is set a loadpoint (space forward, 
abort, and rewind) , and reads one tape record into memory starting at 
location '220 and through '7777 (4K) . Execution begins at '1000 (via a 
JST '777). 

FIOPPY (6): Reads record (track 1, sector 1, 448-word PRIMOS II 
record format) into memory, starting at location '770. To maintain IBM 
compatibility, the boot alternately tries to read a 448-word PRIMOS 
record and a 64-word IBM record. Execution then begins at ']00« (via a 
JST '777). This boot waits for the drive to come ready and retries on 
status errors. 

SPARE (7): Intended as a user-supplied down-line loader. Currently, 
halts at location '57. 
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PROM Generation 

Generation of control panel PROM is a three-step operation: write, 
assemble (PMA) , and load (LOAD) the control panel boot program 
(CPBCOT); generate a PROM simulator paper tape with the CPBGEN 
program; and physically make the PROM. 

CPBOOT: CPBOOT is the standard Prime control panel bootstrap program. 
It resides on UFD=AIDS on the master disk. There are three general 
rules for generating a control panel boot: 

1. it must be loaded at '1000 in 16S mode, but executable in 
sector zero (all sector bits reset) . 

2. All unused locations in sector '1000 must be set to 0. 

3. A maximum of 256 locations can be used (512 for larger 
control panels) . 

Rules 1 and 2 are satisfied by the use of absolute offsets to the 
proper values and added to all addresses in memory reference 
instructions and an initial instruction sequence of: 

D16S 

ABS 

ORG '1000 

BSZ 512 

ORG '1000 

Offsets are computed and used as follows: 



PBD EQU 6-* 

'1000 PB2 DATA 7 

'1001 LDA *-l+PBD 

'1002 LDA PB2+PBD 



(*='1000) 

at '1000, to be loaded at 6 
(*='1001, '1001-1+6- '1000=6) 
(PB2= '1000 , '1000+6- '1000=6) 



OVER EQU '1042 



for subsequent device boot offsets 
actual location = '50 



STD EQU OVER+PBD-* 
'1051 START ANA Sl+STD 



*1052 




SNZ 




'1053 




JMP* 


STE+STD 


'1054 




E64R 




'1055 




JMP* 


1 


'1056 


SI 


DATA 


'177700 




STE 


EQU 


*+l 


'1057 




DATA 


'1000 



(*='1051) 

(Sl= *1056 , '1056+ '1042+6- '1000- '1051 

= '55) 

(STE='1060, '1060+ '1042+6- '1000- 
'1051= '57) 



(next location contains '1000) 
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The number of locations in the auto-start boot is computed by 

Diu-dinRi- j.ioDiu— J.VJJ.— /. £idi;ii cicvja;*; jXkjl, dib WfcJ-LX cits trie pie— JJQOt, 

defines its own base offset to make the code easier to read. The use 
of these bases as memory reference modifiers requires that no literals 
be used. A FIN pseudo-op is placed at the end of each boot to allow 
easy identification of any literals so that they may be replaced with 
appropriately named locations. Since the boot program must be wholly 
contained within sector 1 (no LOAD generated cross sector links) , 
instructions of the form LDA -1, 1 cannot be used. The command file 
C CPB, also on UFD=AIDS, produces a SAVE file named *CPB. CPBOOT 
occupies 240 i '360) locations of PROM. 

CPBGEN: CPBGEN punches a PROM simulator tape of locations '1000- '1777. 
Since the control panel u-code expects the PROM to contain the one's 
complement of the desired locations, CPBGEN performs a preliminary 
backscan and inverts all locations except the unused trailing zeroes (a 
is inherently more reliable than a 1 in PROM) . Since PROM comes in 
eight X 512-bit chips and the PROM simulator loads two parallel 8-bit 
banks, CPBGEN first punches all left bytes and then all right bytes. A 
given byte is punched as two ASCII hexa-decimal digits followed by an 
ASCII apostrophe. For example, the bit pattern 10100110 is viewed as 
1010/0110 = C6 and is punched as '303/ '266/ '247 . A TAPE-ON ''222) 
turns the reader on and a TAPE-OFF ( '224) turns the reader off. The 
final tape format is: 

leader (48 inches): TAPEON: left bytes (0-'777): TAPEOFF: 
blank tape (48 inches): TAPEON: right bytes (0-*777): TAPEOFF: 
trailer (48 inches) 

CPBGEN resides on UFD=AIDS of the master disk and the command file 
C_CPBG produces a run file named *CPBG. To punch a paper tape of 
CPBOOT, the following sequence of instructions must be used: 



FILMEM 




ensure sector '1000 filed with zeroes 


RESTORE 


*CBP 


into '1000- '1777 


ASSIGN 


PUNCH 


(PRIMOS III only) 


RESUME 


*CPBG 


at '2000 


UNASSIGN 


PUNCH 


(PRIMOS III only) 



Physical PROM: To create the physical PROM, load the paper tape 
produced by CPBGEN into the PROM simulator and verify that the load is 
good. Use the PROM simulator to blow the actual PROM chips and insert 
them into the control panel. 

Key-in Substitutes for Control Panel Boots 

Since the auto-load control panel PROM function is optional on some 
Prime computers, hand keyed- in programs are necessary. Because 
programs keyed in are likely to disappear after one use, these programs 
should be as short as possible. 



January 1977 



APPENDIX A MAN2603 



SECOND-LEVEL DISK BOOTS (BOOT) 

The control panel disk bootstraps (FHD/MHD/FLOPPY) read one 448-word 
PRIMOS record from record of the selected device into memory, 
starting at location '770, and begin execution at '1000 in 16S mode. 
Regardless of the device booted from, the second level boot is the same 
and can, in turn, read PRIMOS II into memory from any PRIMOS II disk in 
the system. The source is named BOOT and resides in the UFD=FIIAID on 
the master disk. The run file on record is also named BOOT and 
resides in the MFD. The storage module bootstrap is a 1040-word 
record, and it can bootstrap PRIMOS II from any device. 

BOOT OPERATION 

BOOT performs the following instructions: 

Cleans up parity, non-destructively, throughout memory. 
Sizes available memory. 

Requests, from the operator, which device to boot from. 
Attaaches to the MFD on that device. 
Attaches to UFD=DOS. 

Depending upon memory size and/or sense switches, reads 
DOS16, *DOS24, *DOS32, or *DOS64 in memory and starts them. 

There are three possible outcomes of a boot operation: a successful 
boot, in which case PRIMOS II takes control; a deteacted error, in 
which case the boot returns to request which device to boot from; or 
an undetected error, such as non-existent device, in which case the 
boot hangs. 

When started, the boot types: 

PHYSICAL DEV = 

The operator response should be the physical unit number as defined for 
the PRIMOS II STARTUP command. The format of the unit number as of 
revision 11 is: 

Bits 1-4: head offset divided by 2 (4002 controller and 
storage module only) 
5-8: # heads divided by 2 (4002 controller and storage 
module only) 
9: alternate device (4002 controller and storage 
module only) address (Bit 9 set) 
BiTs 10-13: Type = type 4000 controller and MHD 

1 Type 4000 controller and FHD 

2 floppy 

3 Type 4000 controller 8-sector MHD 

4 Type 4000 controller 64-sector FHD 

5 Type 4000 controller 32 sector MHD 

6 storage module 
7-17 unused 

Bits 14-16: Unit = Physical drive number. For 4000 
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MHD*s, even units are upper platters 
and odd units are lower platters of the 
drive number in bits 14 and 15. For the 
storage module, bit 16 is the low order 
bit of the number of heads/partition 
(bits 5-8) . 

Which DOS (*D0S16, *DOS24, *DOS64) is read in is determined by either 
memory size of Sense Switches 1, 2, and 3 in the following manner: 

If all sense switches are reset, the highest memory DOS that will 
fit in available memory is read. 

If any of the sense switches are set, they are treaded as the most 
significant bits of the high address of memory +1. *DOS64. cannot 
be forced by setting sense switches. 

Sense Switch Address DOS 










highest that will fit 


'20000 






error 


*30000 






*D0S16 


'40000 






*D0S16 


'50000 






*DOS24 


'60000 






*DOS24 


*70000 






*DOS32 


'1X0000 


(x=don 't 


care) 


*DQS32 



Once the boot has been successfully brought into memory by the control 
panel boot, it can be reexecuted by MASTER CLEARing and STARTing at 
'1000, If a status error is detected on the device, BOOT will restart 
automatically. All drivers will wait for the device to come ready. 

Building BOOT 

The BOOT program is stored as a normal PRIMOS II SAVE file on a normal 
PRIMOS II format record (=0) . Consequently, physical record contains 
first an 8-word PRIMOS II record header, second a 9-word PRIMOS II SAVE 
file header, and finally the BOOT program itself. The 8-word PRIMOS II 
record header is eliminated by reading the record starting at '770 but 
starting execution at *1000, the first word of the 9-word SAVE file 
header. For the storage module, the PRIMOS II record header is 16 
words long, but the record is read starting at location '760. 

The SAVE file header is as follows: 

word = start address fSA) (must = '3011) 

1 = end address (EA) (must be correct) 

2 = program counter (PC) 

3 = A-register 

4 = B-register 

5 = X- register 

6 = Keys 

7 = unavailable 
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'10 = unavailable 



Since execution starts at '1000, the start address must be '3011, which 
is also a JMP '10] 1 (since the boot is guaranteed to be executed in 16S 
mode either by MASTER CLEAR or the control panel boot) . The boot 
actually executes in sector '1000 and so must be loaded there (at 
'1011) , then later moved (PSD or TAP) to '3011 and SAVEd there (thus 
requiring the end address to be correct) . Because BOOT can never be 
executed as a caonsole command (it cannot execute in sector '3000) , the 
PC, A-register, B-register, X-register, and Keys are available as 
constants to be used by BOOT. They have been defined as follows: 

PC =0 Short boot (448-word record! 

= 1 Long boot (1040-word record) 

A =0 Not used 

B = '110 Option A master clear default control register 

X = "27 SOC master clear default control register 1 

Keys = '74000 SOC master clear default control register 2 

Once a BOOT has been placed on a disk, it can be copied to another disk 
with the following command sequence: 

A MFD XXXXXX a 

RESTORE BOOT 

A MFD XXXXXX b 

SAVE BOOT 

Since the save parameters can be specified, the PC, A, B, X, and Keys 
registers can be set to other than master clear defaults for option A 
or SOC to allow other types of system consoles to be configured to the 
system. When changing any of these values, care must be taken not to 
change any of the others. Also, special care must be taken if 
transferring a boot to or from the storage module. If the boot is 
restored from other than the storage module, the high address will be 
'3667 and the PC=0. This must not be changed, even if saving onto a 
storage module. When restoring from the storage module, hnowever, the 
high will be greater than "3667 and PC=1. To save it onto other than a 
storage module, the high must be specified as '3667 and PC=0. 

The run-file of the boot will be properly placed on a disk by the MAKE 
program. Also, the file *BOOT will be produced as a result of running 
the command file C<-MAKE. *BOOT is a copy of the boot exactly as it 
appears on record of a storage module, and hence can be restored and 
saved, just as the file BOOT in an MFD. 
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DISK RECORD HEADER FORMATS 



Disk Record Header Formats 



Word No. 


448-word record 


1040-word record 





Record Address 


Record Address-high 


1 


Beginning Record Addr 


Record Address-low 


2 


Forward Pointer 


Beginning Record Addr-high 


3 


Backward Pointer 


Beginning Record Addr-low 


4 


No. of Data Words 


No. of Data Words 


5 


File Type 


File Type 


6 


Spare 


Forward Record Addr-high 


7 


Spare 


Forward Record Addr-low 


8 


Data Words 


Backward Record Addr-high 


9 


Data Words 


Backward Record Addr-low 


10 


Data Words 


Spare 


11 


Data Words 


Spare 


12 


Data Words 


Spare 


13 


Data Words 


Spare 


14 


Data Words 


Spare 


15 


Data Words 


Spare 


16 


Data Words 


Data Words 



NOTES: 

All disks except the storage module have 448-word records. 
Storage modules have 1040-word records. 

The Beginning Record Address of the first record in a file points 
to the directory (UFD or segment) entry of the file. In all 
other recorads, the BRA points to the first record of the file. 

The forward pointer contains the address of the next sequential 
record in the file or if it is the last record in the file. 

The backward pointer contains the address of the previous record 
in sequence or if it is the first record in the file. 

The file type is only valid in the first record in the file. 
Legal values are: 

SAM file 

1 DAM file 

2 SAM segment directory 

3 DAM segment directory 

4 UFD 
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If the file is the record zero bootstrap (BOOT) or the disk 
record availability table (DSKRAT or volume name) and the disk 
has a 1040 record size (storage module) , Bit 1 (100000 octal) of 
the file type will be set. 
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INTRODUCTION 

This update documents Rev. 14 features of PRIMOS II, III, and IV that are 
available only at the system operator's console. 

Rev. 14 features that are available to interactive users are described in 
PTU 42. 

Information in this update is aranged as follows: 

• New or Improved Commands 

• Rev. 14 Bootstraps (PRIMOS III and IV) 

• Event Logging (PRIMOS III and IV) 

• PRIMOS IV Computer Room Features 

• PRIMOS III Computer Room Features 

• PRIMOS II Computer Room Features 

NEW OR MODIFIED COMMANDS 

Following are the new or improved Rev. 14 system terminal commands, in 
alphabetical order. All commands apply to PRIMOS II, III, and IV except 
as specified opposite the command caption. 
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CHAP (PKEMDS III) 

CHAP is a new internal operator comnand that changes a user's times lice. 
The format of the cemmand is: 



CHAP [J-userno>] [oriority] [timeslice] 
L ALL J 

userno is the number of the user to be modified in the form -nn 

priority is an octal parameter which is ignored 

timeslice specifies a new timeslice value in tenths of a second 

If specified as 0, the timeslice is reset to the standard value. If 
emitted, the timeslice is left unchanged. If both priority and time- 
slice are emitted, the timeslice is reset to the standard value. If 
ALL is specified instead of -userno , the specified changes will be made 
to all users. (Note: the timeslice for user 1 cannot be modified.) 

CHAP (PRIMDS IV) 

CHAP is a new internal operator command that changes a user's timeslice 
or priority level in the ready list. The format of the cemmand is: 

CHAP [< -userno)] [priority] [timeslice] 
I ALL J 

where: 

userno is the number of the user to be modified in the form -nn 

priority is the priority level to be assigned to the user in the 

form of an integer frcm 3 (highest priority) to (lowest 
priority) . If omitted, the priority is left unchanged 

timeslice specifies a new timeslice value in tenths of a second 

If specified as 0, the timeslice is reset to the standard value. If 
emitted, the timeslice is left unchanged. If both priority and time- 
slice are emitted, the user's priority is reset to 1 (the level on which 
users normally run) , and the timeslice is reset to the standard value. 
If ALL is specified instead of -userno , the specified changes will be 
made to all users. (Note: the level and timeslice for user 1 cannot 
be modified.) 



I$:v. 43-4 November 1977 



KTU43 PRIMOS REV. 14 



FIXRAT 

As of Rev. 14, the FIXRAT utility has been changed to accept a multi-record 
bootstrap (file BOOT placed in ufd MFD by the MAKE program) , since the Rev. 
14 bootstrap is longer than one record on non-Storage Module devices. 
Earlier revisions of FIXRAT will not accept the Rev. 14 bootstrap. 

No change to FIXRAT operating procedures is necessary. 



LOOK (PRIMOS IV) 

LOOK is a new internal operator command that provides access to any seg- 
ment in the system. The format of the cairoand, which must be preceded 
by an 'OPR 1" is: 

LOOK [-userno] [segno] [access] [mapseg] 



userno is the number of the user owning the segment and defaults to 
user 1 

segno is the number of the segment to be examined. It defaults to 
'6000 (the Ring stack segment for the user) 

access specifies the access rights to be granted as in the SHARE com- 
mand and defaults to '200 (read-only) 

mapseg is the segment of user l's address space into which the speci- 
fied segment is to be mapped. The default is '4001. 



MAKE 

At Rev. 14, the MAKE catmand has been changed to create new-style parti- 
tions by default. Formerly the catmand MAKE NEW was required to achieve 
this. The MAKE catmand is still capable of creating old-style partitions- 
issue the catmand MAKE OLD . Either way, the MAKE program prints a message 
informing the user of the type of partition created. 

Since MAKE now places the Rev. 14 bootstrap on the partitions it creates, 
Rev. 14 FIXRAT must be used on those partitions. Earlier revisions of 
FIXRAT do not accept a multi-record bootstrap. Other than the bootstrap, 
no changes have been made to the partition format of this revision. 
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MAXUSR (PRIMOS IV) 



are allowed to be logged into PRIMOS IV at any time. Normally, this 
variable is set to NUSR — the number of configured users. When it is 
necessary to limit the number of users on the system, the command 



MAXUSR n 



can be used. Thereafter, no more than n (octal) users will be allowed 
to login. If the number of users is already above n, no user will be 
forcibly logged out, but no new users will be allowed to login and no 
phantoms will be started. Users attempting to login or start a phantom 
will receive the error message 



MAX NO. USERS EXCEEDED 

There are two situations in which this facility will be useful: 

1. At cold start, if there are modifications to be made to PRIMOS, 
setting MAXUSR to 1 or 2 will prevent users from logging in until 
the operator decides it is appropriate. (The MAXUSR command 
should be entered before setting the date and time.) 

2. When the system is to be shut down, setting MAXUSR to zero will 
prevent new logins just before the shutdown. 



SETIME (PRIMOS III and IV) 

PRIMOS now requires two digits of year to be specified in the SETIME 
command. Both digits are stored internally and returned by the TIMDAT 
SVC. (Most programs using the current format returned by TIMDAT should 
continue to work until the end of this year!) Validity checking is 
also performed on the parameters of the SETIME command. If the date 
or time is not entered correctly, the following message will be printed: 



CORRECT FORMAT IS: ^MMDDYY -HHMM 



PRIMOS new also advances the month and year correctly. 
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SHARE 

The gate segment — segment 5 — should not be specified in a SHARE com- 
mand. If it is given anything but :100 access rights, direct-entrance 
calls from user space will cause ACCESS VIOLATION messages. 



SPOOL 

Operator Commands 

At Rev. 14, the spooler supports a host of commands which allow the system 
operator to "communicate" with the spooler background phantom (s) . They 
allow the operator to perform utility operations, such as changing the 
current form type, stopping the spooler at the end of the current file, 
restarting or aborting the current file, etc. 

Operator commands are issued in the command line following the "SPOOL" com- 
mand, prefixed by a dash and separated by a space. These commands must be 
entered from a user whose login name is identical to that of the spool phan- 
tom with whom he wishes to "oannunicate"; should the user be logged in under 
a different name, the spool program will respond with an error message and 
the command will be ignored. 

Following is a list of operator commands currently recognized: 



Command Argument 



ABORT 



none 



DROP none 



RESTART none 



LOGOUT none 



Description 

Cease printing the current file but do not drop it from 
the queue. This allows the operator to force all short 
files to be printed immediately followed by a restart 
of the file which was currently printing. Also, it for- 
ces a previously issued paper change to occur immediately 
if a file was printing when the PAPER command was issued 
(see below) . 

Cease printing the current file and drop it from the 
spool queue. This command allows the operator to abort 
a spool request after it has started printing. 

Restart printing of the current job. This command is 
usually issued after a paper jam when the operator 
desires to reprint the file. 

Log out. Upon receipt of this command, the spool phan- 
tom logs out immediately. If a file was printing at the 
time, that file is not dropped from the queue and will 
be reprinted when the spooler is restarted. 
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Conmand Argument Description 

PAPER 'type Change paper. This command informs the spooler that 

the operator wishes to print files with the specified 
form type. If no file is printing when this command 
is issued, the response from the spool program is to 
request the operator to mount the specified form and 
issue the 00 command (see below) when ready. If a file 
was printing when this command is issued, the file is 
allowed to finish before the message is sent to the 
system console. 

HANG none Inhibit printing and/or queue scanning operations. The 

user must issue the GO command to resume normal opera- 
tion. 

GO none Resumes spooler operation following a HANG, PAPER, or 

FINISH (see below) command. 

LENGTH r lines Set form length. This command specifies the default 

form length in number of lines. If the user's print 
file does not contain a reset-length control code, this 
form length is used. The r lines argument represents 
the number of printable lines per page. 

TIME rsecs Set acknowledge time-out time. This command specifies 

the amount of time, in seconds, the SPOOL program waits 
for an acknowledge from the spool phantom after a com- 
mand is issued. When this tine limit is exceeded, a 
TIME-OUT error message is printed and SPOOL exits to 
command mode. The default time is 100 seconds. 

USER usrnum Specify spooler user number. This command is used when 

more than one spooler is running on the system and spe- 
cifies the spooler, by user number, to which the follow- 
ing catmands are directed. An error message is printed 
if this command is not used on a system where multiple 
spoolers are active. 

FINISH none Finish current file. The spooler prints the remainder: 

of the current file, prints a message on the system con- 
sole informing the operator that it has finished, and 
then goes into a "HANG" mode, as described above. The 
operator must issue a GO command to continue. 

The following messages may appear as a response to a command issued by the 
operator: 



ACKI^OWLEDGED 
The command was received and acknowledged by the spool phantom. 
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ANOTHER REQUEST PENDING 

This command could not be honored because there was another command which 
had been issued but not acknowledged by the spool phantom. 



NO SPOOLER 

If a user number was specified, no spooler is active on that user number, 
else no spool phantom is active on the system. 



SPOOLER IDLE 

An abort, drop, restart, or finish command was issued and the spool phantom 
was not printing a file. 

PRTVILEDGED COMM2ND 

The user issuing the command was not logged in under the same user name 
as the spooler phantom to which the command was directed. 

TIMED OUT. 

The spool phantom did not acknowledge the command within the time limit. 
The command remains pending, but the acknowledge or negative acknowledge 
status is lost. 

MULTIPLE SPOOLERS ACTIVE; USER # MUST BE SPECIFIED 

The user issued a command without specif iying a user number with multiple 
spool phantoms active. 

ACKNOWLEDGED - MOUNT NEW PAPER, TYPE 'GO' TO CGNTINUE 

The spooler has entered "hang" mode, waiting for the operator to mount the 
form type just specified. To start printing files with the given type, 
type "SPOOL -GO" after mounting the appropriate form. 

ACKNOWLEDGED - SPOOLER BUSY - A MESSAGE WILL BE SENT TO THE 
SYSTEM CONSOLE WHEN THE CURRENT JOB IS DONE 

The PAPER command just issued was acknowledged, but the printer is currently 
printing a file with the previous form type. When the spool phantom sends 
the message to the system console, the operator should mount the specified 
form and type "SPOOL -GO" to continue from the user terminal. 

Examples : 

Stop printing and drop the current print file from the queue: 

OK, SPOOL -DROP 

GO 

WAIT ... ACKNOWLEDGED. 

OK, 
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Change the form type to "SZ.132": 

OK, SPOOL -FORM SZ.132 

GO 

WAIT ... ACKNOWLEDGED - MOUNT NEW PAPER, TYPE 'GO' TO CONTINUE. 

OK, SPOOL -GO 

GO 

WAIT ... ACKNOWLEDGED. 

OK, 

Change to default form type: 

OK, SPOOL -FORM ' ' 
GO 

WAIT . . . ACKNOWLEDGED, SYSTEM BUSY - A MESSAGE WILL BE SENT TO THE 

SYSTEM CONSOLE WHEN THE CURRENT JOB IS DONE 
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REV. 14 BOOTSTRAPS (PRIMOS II, III, IV) 

As of Rev. 14, the bootstrap (placed on all disks by the MAKE program as 
file BOOT in ufd MFD) understands both old and new partitions, and is the 
same on all disk devices. Formerly, the previous bootstrap was different 
on Storage Module devices and did not handle new partitions at all. No 
change to either control-panel operating procedures or PROM are required 
to utilize the Rev. 14 bootstrap. 

The bootstrap is now 770 (1402 octal) words long (including the saved-file 
header) . It occupies two records on non-Storage Module devices and one 
record on Storage Module devices. The control panel loads only the first 
record of the bootstrap, but the first record locates and reads the remain- 
der of the bootstrap when it needs to. 

Inasmuch as the bootstrap can now be longer than one record, the Rev. 11 
artifice of truncating the bootstrap on non-Storage Module devices by tam- 
pering with the saved-file, ending-address, and program-counter parameters 
is no longer necessary. The correct parameters for the Rev. 14 bootstrap 
as supplied by the factory are the same on all devices, and are: 



SA, EA, , A, B, X, K= 

30011, 4401, 0, 0, 110, 27, 74006 



As in the past, the last three saved-file parameters are used as console 
typewriter control words. The B-register setting is used as the Option A 
control word, the X-register setting as SOC control word one; the keys 
setting left byte is used as SOC control word two, and the right byte as 
the number of characters of end-of-line delay. (The number of end-of-line 
delay characters is not used by the bootstrap, which has a built-in con- 
stant delay of six characters, but it is passed along to PRIMOS II as 
described in the next paragraph.) The bootstrap can be changed to set- 
tings for other terminal characteristics either permanently (by saving it 
with new B, X, and K parameters) or termporarily (by patching locations 
001004, 001005, and 001006 of the copy in memory, followed by a MASTER 
CLEAR and RUN) . 

At Rev. 14, all versions of PRIMOS II have been modified to automatically 
pick up their console typewriter control words directly from the boot- 
strap. It is no longer necessary to patch PRIMOS II for nonstandard ter- 
minal characteristics. 

Partitions containing the Rev. 14 bootstrap require the Rev. 14 FIXRAT 
Utility. Prior revisions of FIXRAT consider a multi-record bootstrap to 
be an error. 
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EVENT LOGGING 

The event logging mechanism for Rev. 14 of PRIMOS III and IV is unchanged 
from Rev. 13 (see PTU32) . The LOGPRT program, however, has been enhanced 
and the log file entries have been modified. Note that the operation of 
LOGPRT is identical under PRIMOS II, III, and IV with the single excep- 
tion of the -SPOOL option, which is not supported under PRIMOS II. 

New LOGPRT Options 

LOGPRT has the same format as Rev. 13: 

R LOGPRT [destination] [option] [option] . . . 

but the option list has been expanded to include the following function: 

HELP A list of LOGPRT options is printed. The LOGPRT carmand 
must be retyped after the options are printed. 

FROM itmddyy Only LOGREC entries from the specified date to the 
latest entry are processed. 

TYPE tl t2 . . . Process entries only of the indicated types . The types 
(tl, t2, etc.) can be any of the following (any unique 
abbreviations are acceptable) : 

GOLD Cold Starts 

VJARM Warm Starts 

TIMDAT Time/date entries 

CHECKS Machine checks (including memory parity) 

DISK Disk errors 

OVERFL LOGREC overflow entries 

SHUTEK Operator shutdowns 

CHK300 P300 machine checks 

PAR300 P300 memory parity checks 

MOD300 P300 missing memory module checks 

TYPE10-TYPE15 Entries for types 10-15 

Note that the time/date stamps associated with the 
selected entries will not be processed unless TIMDAT 
is explicitly selected, for example, '-T D T' will 
process all disk errors and their associated time/ 
date stamps. If TIMDAT alone is specified, all time/ 
date stamps in LOGREC will be processed. If TLMDAT 
is specified in conjunction with one or more other 
types, only the time/dates of the selected types 
will be processed. If the -TYPE option is not speci- 
fied, all entries will be processed. 
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-SPOOL (PRIMOS III and IV only) Spool the output file when 
done. LOGPRT will print the name of the output spool 
file and a long/short indication. 

-DELETE Delete the output file when done (makes sense only 
when using the -SPOOL option) . 

-PURGE Empty LOGREC when done (this option cannot be abbrevi- 
ated) . 

LOGPRT File Entries 

LOGPRT now outputs the following entries: 

GOLD START 
A cold start of PRIMOS was performed. 

WARM START 
A warm start of PRIMOS was performed. 

MACHINE CHECK (xxx) DSWSTAT = ssssss ssssss DSWRMA = yyyyy rrrrrr 
rrrrrr DSWPB = pppppp pppppp 

A machine check occurred. DSWSTAT, DSWRMA, and DSWPB constitute the DSW 
at the time of the check, 'xxx' is an encoding of the machine check code 
and 'Not RCM Parity 1 in DSWSTATH as follows: 

BPD Peripheral Data Output 

BPAI Peripheral Address Input 

BMD Memory Data Output 

RCD Cache Data 

BPAO Peripheral Address Output 

RDXI RDX-BPD Input 

BMA Memory Address 

RF Register File 

RCM RCM Parity Error (XCS only) 

If the RMA INVALID bit is set (bit 9 of DSWSTATL) , 'yyyyy 1 is ' (INV) • , 
otherwise 'yyyyy' is absent. 



MISSING MEMORY DSWSTAT = . . . 

A missing memory module check occurred. Information is as for a machine 
check except the machine check code (xxx) does not apoear. 
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MEMORY PARITY (xxxx) DSWSTAT = . . . PPN,WN = pppppp wwwwww 

A memory parity error occurred, 'xxxx* is either 'ECCC' (corrected) or 
'ECCU' (uncorrected) . 'PPN,WI=pppppp wwwwww' identifies the physical 
page and word number of the error. For an ECCC error, the PPN is followed 
by 'BIT = xx ', where 'xx' identifies the bit in error — 1-15 for bits 
1-15, RP for right parity, LP for left parity, C2, C4, C5 for other check 
bits, MB for multibit, NE for no error. (This is taken from the ECCC Syn- 
drome field in DSWSTATL.) 



DISK xx ERROR DVNO = dddddd (typecode) CRA = rrrrrr rrrrrr 
CYL = ccc HEAD = hh RECORD = rr RCRA = aaaaaa aaaaaa 
STATUS (ACCUM)= SSSSSS STATUS (LAST) = 111111 RETRIES = 
tt mmmmmm 

A disk error occured during an 'xx' operation, where 'xx' is 'RD' for read 
or 'TO" for write. DVNO gives the device number, 'typecode' gives the 
controller number and device type (MHD = > moving head disk, FHD = > fixed 

head disk, SM => storage module) . CRA qives the record address, which 
is broken up into CYL (cylinder) , HEAD, and RECORD address (all in decimal) . 
For a read operation, RCRA gives the CRA read on a CRA error. STATUS 
(ACCUM) is the OR of all status bits obtained during retries. STATUS (LAST) 
is the status of the last operation. 

RETRIES gives the number of retries attempted. If RETRIES is less than 10, 
the operation was completed successfully — mmmmmm will be ' (RECOVERED) ' . 
If RETRIES = 10 and the error could not be corrected by ECC, mmmmmm is 
' (UNCORRECTABLE) ' . If an ECC error has been successfully corrected by the 
software, m m u in m m is WDRDNO= and CORRECTION=, which give the word number in 
the record and the 32-bit correction pattern user. 



MACHINE CHECK USER = nn PC = pppppp 

This is the format of a machine check message on a PRIME 300. USER gives 
the user number (decimal) , PC gives his PC at the time of the check. 



MEMORY PARITY 
A PRIME 300 memory parity error occurred (see also next entry) . 

MEMORY PARITY PPN = pppppp WN = wwwwww CONTENTS = cccccc 

This is the format of an entry for a PRIME 300 memory parity error encoun- 
tered during a warm start memory scan. Given are the physical page number 
(PPN) , word number offset in the page (WN) , and incorrect contents. 

MISSING MEMORY 
This is a PRIME 300 missing memory check entry. 
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LOGBUF OVERFLOW — nnnnn ENTRIES LOST 
'nnnnn' (decimal) event entries were lost due to overflow of LOGBUF. 

SHUTODWN BY OPERATOR 

The operator issued a 'SHUTDN ALL 1 command. (This automatically dumps 
LOGBUF.) 

*** LOGREC EMPTY *** 
This message is printed if LOGPRT finds no entries in LOGREC. 

*** END OF LOGREC — nnnnn ENTRIES *** 

This message is printed when LOGPRT reaches the end of LOGREC. 'nnnnn 1 
(decimal) gives the number of entries processed not including date/time 
and LOGBUF overflow entries. 

When all the entries in LOGREC (or other input file) have been processed, 
LOGPRT will normally close the file and exit. If, however, the -PURGE 
option has been specified, LOGPRT will position to the beginning of the 
file before closing, in effect emptying the file. 

Finally, if the SPOOL option is in effect, LOGPRT sends the output file 
to the spool program and prints the name of the resulting spool file. If 
the DELETE option is in effect, the output file is then deleted. 
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PRIMOS IV COMPUTER ROOM FEATURES 

Building and Running PRIMOS IV 

The basic procedures for building PRIMOS IV are unchanged. Sane minor 
changes have been made in the load sequence, and there are several new 
source modules. The MAPGEN program has been modified so that it 
automatically generates the appropriate C-KX)LD file. 

Running C*LOAD will result in the creation of two new PRxxxx files — 
PR0005 and PR6000. PR0005 is the gate segment for direct entrance calls 
and PR6000 is the Ring stack segment. 

FIGCOM Additions ; Two new system variables — DEFERA and DEFKIL have been 
added to FIGCOM. These two words define the default character-erase and 
line-kill characters for all users. (As described below, each user also 
has control over his own erase and kill characters.) 

Speed Selection for System Console : The speed selection for the system 
console is now controlled by the setting of the B register for *COLDS. 
For a 10 CPS terminal, the B register should be set to octal 110 (this is 
the default) . For a 30 CPS terminal, set the B register to 1010, i.e.: 

REST *COLDS 

SAVE *COLDS 4/1010 

This procedure will make all necessary changes for both OPTION A and SOC 
and will issue an internal DELAY command. 

Configuring Memory Size : The fourth parameter of the CONFIG command 
controls the number of pages on physical memory to be used. It is used 
to set MAXPAG — location '1522 of *COLDS at REV 13. 

Configuring Extended Instruction Set UII Package : It is possible to use 
a subset of the PRIME 500 instruction set on the PRIME 400, in particular 
the decimal arithmetic and character string manipulation instructions. 
These instructions are generated as object code in programs compiled 
by COBOL in V-mode. If the XTSUII package is installed, these 
500 instructions will trap to the PRIMOS IV operating system and will 
be simulated by PRIMOS IV subroutines. First copy the file UI2000 
frcm UFD SYSTEM on master disk Volume I©14Bl to UFD SYSTEM on your 
disks. To install the XISUII package, type the following caimands 
at the system console or incorporate them into your C PRMO canmand 
file: 

ATTACH SYSTEM 1/177777 

OPR 1 

SHARE UI2000 2000 

OPR 

A 
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Versions of PRIMPS IV ; PRIMOS IV is distributed in three versions — 
64-user, 16-user, and a large address-space 16-user version. The default 
characteristics of each version are as follows: 

USERS NUMBER SEGMENTS SEGMENTS PER USER 

64 192 32 

16 192 8 

16 320 256 



Running PRIMOS ; The UFD's containing the run files and carmand files 
for the three versions are in PR4.64, PR4.16, and PR4L16. To run PRIMOS, 
attach to the appropriate UFD and type 'R PRIMOS'. 

Note 

BREAK$ now maintains a QUIT inhibit counter, rather 
than a single flag. External login programs (which 
are entered with QUITs inhibited) should enable breaks 
before calling EXIT. In other words, they should always 
enable QUITs one time more than the number of inhibits; 
otherwise the user will be logged in with QUITs 
inhibited. (If this happens, causing any error will 
re-enable QUITs.) 

Number of Segments, Paging Space 

The number of segments required by PRIMOS is given by: 

NSEG = N + 9 + X 

where N is the total number of configured users — CONFIG parameter 
(number terminal users) + CONFIG parameter 6 (number phantoms) — and 
X is the total number of segments to be available to users. NSEG must 
be less than or equal to 192. If it is desired to limit NSEG to a 
number less than 192 (to preserve paging space, for example) , the 
location NSEG in segment 4 can be patched in PR0004 (run C-KDLD after the 
patch) . If NSEG is not modified, X defaults to 119. Given X from the 
above, the paging disk space requirements are given by: 

records = (3.5 + X) * 64 * records/page 

New Devices Supported 

Two Magtape Controllers : PRIMOS IV now supports two magtape controllers 
at physical device address '14 (first controller) and '13 (second 
controller) . Up to eight drives can be supported, unit numbers 0-7, 
device names MT0-MT7. 
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Two SMLC Controllers : PRIMOS TV now supports two SMDC controllers and 
four lines. The physical device addresses are "50 (first controller) and 
'51 (second controller) . The four lines are referred to as logical line 
numbers 0-3, which are mapped to physical device address and physical 
line number by the SMLC driver. These logical lines can be configured 
over the two controllers as desired at system load time. The standard 
configuration is: 

Logical lines 0,1 — > controller '50, physical lines 0,1 
Logical lines 2,3 — > controller '51, physical lines 0,1 

Four tables have been set up to handle the mappings and have been defined 
as entry points. The tables are defined as follows: 



CONTBL(4) Maps logical line number to physical device address. 

PLINTB(4) Maps logical line number to physical line number. 

SMLCTB(4) Logical list of physical device addresses. Requires 
a table lookup to get offset into LLINTB. 

LLINTB(4,2) Maps physical line number (first index) and logical 

device offset (second index) to a logical line number. 
An entry of -1 indicates a null value. 

Full Address Space for User 1 

User 1 (SUSR) has been given a full address space. It is therefore 
possible to run external commands from the system console -no 'OPR I 1 
is required. (Note, however, that if other users are logged in, user 1 
should remain attached to CMDNC0.) 

PRIMSNET Extension 

PRIMENET now supports HSSMLC links. 

FAM 

FAM Extensions : FAM now supports all file system operations, including 
those on new partitions, across PRIMENET. 

Installing FAM : At REV 13, FAM automatically ran at a higher priority 
than other users to give reasonable response to user requests to FAM. 
At REV 14, FAM runs as a normal interactive user unless the CHAP command 
is given to increast its priority. FAM is started as before: 

A FAM 1/177777 PH PH«FAM A 
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Warm Start 

Warm start now requires Revision 10 or above microcode. An attempt to 
warm start with the wrong revision will result in an immediate halt at 
WARMH^ a cold start is necessary. 

A successful warm start will no longer QUIT each user. Instead, the 
message '***** WARM START *****' is sent to all terminals, and all users 
are automatically restarted (e.g., typing 'S' is no longer necessary). 
Because of this procedure, however, a warm start will not always cure a 
hung system; in general, it is best to attempt a warm start only after 
the system has halted. 

Disk Error Handling 

STARTUP and ADDISK commands specifying non-existent or not-ready devices 
will no longer hang the system. The following message will be typed on 
the system console (or to the user to whom the device is assigned) : 

DISK pdev NOT READY 

Error Messages from Phantom Users 

When a phantom user is logged out due to an error that caused entry to 
command mode, the following message will be printed on the system 
console: 

PHANTOM nn: <error text> 

where nn is the number of the phantom being logged out and <error text> 
is the text of the last error message generated by the phantom user. 

System Counters, CUSR 

Displayable two-^word counters are now maintained for various system usage 
totals. These quantities and their entry names are total CPU time used 
(CPTOT) , total I/O time used (IOTOT) , and total page faults (PFCN) . 

There is no longer a single variable corresponding to CUSR. A close 
equivalent is the location LEVUSR (segment 4) , which will contain the 
value ' 100000+' I00*current-user-number. User 1 and other users not at the 
normal user priority level will not appear in this location. 
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PRIMDS III COMPUTER ROOM FEATURES 

Building PRIMDS III 

The basic procedures for building PRIMOS III are unchanged. Sane minor 
changes have been made in the load sequence, and there are several new 
source modules. 

FIGQOM Additions : Two new system variables — DEFERA and DEFKEL have been 
added to FIQCOM. These two words define the default character-erase and 
line-kill characters for all users. Each user also has control over his 
own erase and kill characters. See TERM command. 

Speed Selection for System Console : The speed selection for the system 
console is now controlled by the setting of the B register for PRMOSL. 
For a 10 CPS terminal, the B register should be set to octal 110 (this is 
the default) . For a 30 CPS terminal, set the B register to 1010, i.e.: 

REST PRMSOL 

SAVE PRMSOL 4/1010 

This procedure will make all necessary changes for both OPTION A and SOC 
and will issue an internal DELAY command. 

Configuring Memory Size : The fourth parameter of the CONFIG command con- 
trols the number of pages on physical memory to be used. 

Paging Space Requirements 

records = KUSER+1 * 128 * records/page 

where KUSER is the total number of user configured. 

FAM Extensions 

FAM new supports all file system operations, including those on new parti- 
tions, across PRIMENET. 

Error Messages from Phantom Users 

When a phantom user is logged out due to an error that causes entry to com- 
mand mode, the following message will be printed on the system console: 

PHANTOM nn: <error text> 

where 'nn' is the number of the phantom being logged out and <error text> 
is the text of the last error message generated by the phantom user if the 
phantom is not using cenmand output. 



REV, 43-20 November 1977 



PTU 43 



PRIMOS REV. 14 



PRIMOS II COMPUTER ROOM FEATURES 

Versions of PRIMOS II 

At Revision 14, another version of PRIMOS II, namely Q-DOS, is supplied 
on the Master Disk in addition to the versions which were previously 
supplied. 

Q-DOS is 40000 octal locations in size (including file-system buffers and 
hybrid commands) and supports new file-system partitions, new file-system 
calls, and new long-name command lines. It is loaded in 64R addressing 
mode and requires a processor with the high-speed arithmetic option. 
Together with the Revision 14 bootstrap, which also handles new partitions, 
Q-DOS makes possible an installation which utilizes new partitions, 
exclusively. 

Relative-mode PRIMOS II remains 14000 octal locations in size 
(excluding file-system buffers and hybrid commands) , is loaded in 
64R addressing mode and can be loaded or called frcm anywhere in memory, 
and does support the Storage Module disk device, but does not support 
new file-system partitions, new file-system calls, or new command 
lines. 

Sectored-mode PRIMOS II is 11000 octal locations in size (excluding 
file-system buffers and hybrid commands) , is loaded in 32S addressing 
mode, and cannot utilize the Storage Module disk or be loaded or called 
from above the 32K boundary. It does not support new file-system 
partitions, new file-system calls, or new command lines. 

As before, the various versions of PRIMOS II are supplied loaded for 
various memory sizes in both real-memory and virtual-memory configurations. 
The real-memory configurations run stand-alone on any Prime processor 
(except that Q-DOS requires high-speed arithmetic) . The virtual-memory 
configurations run in user-space under the PRIMOS III and up operating 
systems on Prime 300 and up processors. 

The locations and names of the PRIMOS II configurations on the Master Disk 
supplied by the factory are: 



ufd 



file 



DOS 


SDOS32 


DOS 


*DOS32 


DOS 


RDOS64 


DOS 


*DOS64 


DOS 


VDOS32 


DOS 


UDOS32 


DOS 


UDOS64 


CMDNC0 


TDOS64 


CMDNC0 


DOSEXT 


CMDNC0 


DOSXT 



contents 



low 



restart high 



32K real-memory S-DOS 067000 070000 077777 
32K real-memory R-DOS 064000 070000 077777 
64K real-memory R-DOS 164000 170000 177777 
64K real-memory Q-DOS 140000 170000 177777 
32K virtual-memory S-DOS 067000 070000 077777 
32K virtual-memory R-DOS 064000 070000 077777 
64K virtual-memory R-DOS 064000 170000 177777 
64K virtual-memory Q-DOS 140000 170000 177777 
saved file containing tybrid commands for S-DOS 
saved file containing hybrid commands for R-DOS 
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When a Master Disk is leaded frcm the processor control panel, the 
bootstrap assesses the size of main-memory physically present on the 
machine and loads file *DOSNN from ufd DOS, where nn is 32 or 64, 
depending upon main-memory size. Setting sense switch one limits 
nn to 32 on 64K machines and Q-DOS is loaded on 64K machines. An 
installation can change this by renaming the files in ufd DOS. For 
example, if an installation desires relative-mode PRIMDS II to load 
on 64K machines, it should rename *DOS64 to QDOS64 and RDOS64 to 
*DOS64. 

With the availability of Q-DOS, the virtual-memory PRIMDS II supplied in 
ufd CMDNCO has been changed from UDOS64 (64K relative-mode PRIMOS II) 
to TDOS64 (64K Q-DOS) . UDOS64 continues to be supplied, but it is now in 
ufd DOS. 

Ml versions of PRIMDS II have been changed to automatically acquire 
their console typewriter control words directly from the bootstrap. It 
is no longer necessary to patch PRIMDS II to match the characteristics 
of a particular typewriter. 

The hybrid commands, which are in files DOSEXT and DOSXT for previous 
versions of PRIMDS II, are internal to Q-DOS, so there is no hybrid 
command file in ufd CMDNCO for Q-DOS. 

Also internal to Q-DOS are all of its file-system buffers. The bottom of 
Q-DOS is fixed at location 140000 octal, independent of the number of open 
file units. Buffers are external to the previous versions of PRIMDS II, 
and are allocated downward frcm the bottom of the operating system toward 
the user program region. 

Utilities Under PRIMDS II 



Beginning with Revision 13, the loaders LOAD, L0AD20, and HILOAD use new 
file-system calls and the new long-name command lines. These loaders 
cannot run under sectored-mode or relative-mode PRIMDS II. The commands 
DLOAD, DL0AD2, and DHLOAD, or else earlier revision loaders, should be 
used instead. Also the ED, FTN, and PMA commands as of Revision 14 
cannot run under sectored-mode or relative-mode PRIMDS II for the same 
reason. Use earlier revision versions of these commands instead. Q-DOS 
accepts the new file system and new command line calls, restrictions 
under Q-DOS. 

Q-DOS and relative-mode PRIMDS II have been fixed to refuse restoring a 
saved file if the operation would overwrite the operating system or its 
buffers. This check is not made in sectored-mode PRIMDS II, and 
unpredictable behavior can result if the error is made. 
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Using Bounce Package 

With Revision 14, the bounce package has been removed frcm the standard 
library FTNLIB in ufd LIB. Thus, new file-system calls (such as PRWF$$) 
execute the corresponding new supervisor calls and expect them not to 
bounce, and old file-system calls (such as PRWFIL) are converted into new 
calls, so the new FTNLIB never executes an old supervisor call. 
Consequently, programs loaded with Revision 14 FTNLIB will not execute 
under relative-mode or sectored-mode PRIMOS II. In addition to FTNLIB, 
another standard library BOULIB is now supplied in ufd LIB, which contains 
the bounce package. In BOULIB, either old or new file-system calls are 
mapped into new supervisor calls, which if bounced are mapped into old 
supervisor calls. By comparison, Revision 12 and 13 FTNLIB mapped old 
file-system calls into old supervisor calls , and new file-system calls 
into new supervisor calls, which if bounced were mapped into old 
supervisor calls. Revision 11 and earlier FTNLIB handled exclusively 
old calls. 

In summary, there are three options for preparing programs at Revision 14 
which must execute under sectored-mode or relative-mode PRIMDS II. First, 
load BOULIB instead of FTNLIB. This is the most costly of memory (since 
the BOULIB bounce package is large) , but results in a program with the 
longest lifetime and best performance under system which support new 
supervisor calls. The second alternative is to load Revision 12 or 13 
FTNLIB. This has an intermediate memory requirement (the bounce package 
is smaller) but results in a program with shorter lifetime (it will stop 
working when old supervisor calls are turned off) and lower performance 
under systems which support new supervisor calls. The third alternative 
is to confine the program to old file-system calls and load a Revision 11 
or earlier FTNLIB. This alternative has the smallest memory requirement. 
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